Запись структуры в файл
writestruct( записывает структуру в файл с дополнительными опциями, заданными одним или несколькими аргументами пары "имя-значение". Для примера можно экспортировать содержимое структуры входа как XML-файл независимо от расширения файла, указанного в S,filename,Name,Value)filename по вызову writestruct(filename,"FileType","xml").
Создайте структуру из текстового файла, содержащего XML-структуру, а затем запишите ее в XML-файл.
Файл music.txt имеет следующую структуру.

Чтение текстового файла music.txt как структура S. Задайте 'FileType' как 'xml' чтобы считать содержимое входа XML- файл.
S = readstruct("music.txt","FileType","xml")
S = struct with fields:
Ensemble: [1x1 struct]
Musicians: [1x1 struct]
Запись S в XML-файл с именем band.xml. Отображение содержимого band.xml.
writestruct(S,"band.xml") type band.xml
<?xml version="1.0" encoding="UTF-8"?>
<struct>
<Ensemble>
<Music>Jazz</Music>
<BandName>Kool Katz</BandName>
<Instrumentation>
<Instrument type="wind">
<Text>Trumpet</Text>
</Instrument>
<Instrument type="percussion">
<Text>Piano</Text>
</Instrument>
<Instrument type="percussion">
<Text>Drums</Text>
</Instrument>
<Instrument type="string">
<Text>Bass</Text>
</Instrument>
<pianotype>concert grand</pianotype>
<drumkit>Bass drum</drumkit>
<drumkit>Floor tom</drumkit>
<drumkit>Snare drum</drumkit>
<drumkit>Hi-hat</drumkit>
<drumkit>Ride cymbal</drumkit>
<basstype>upright</basstype>
</Instrumentation>
</Ensemble>
<Musicians>
<Name role="trumpeter">
<Text>Miles</Text>
</Name>
<Name role="vocalist">
<Text>Roger</Text>
</Name>
<Name role="pianist">
<Text>Diana</Text>
</Name>
<Name role="drummer">
<Text>George</Text>
</Name>
<Name role="bassist">
<Text>John</Text>
</Name>
</Musicians>
</struct>
Чтение файла music.xml как структура S.
S = readstruct("music.xml")S = struct with fields:
Ensemble: [1x1 struct]
Musicians: [1x1 struct]
Запись S в XML-файл с именем band.xml. Назовите корневой узел JazzBand. Отображение содержимого band.xml.
writestruct(S,"band.xml","StructNodeName","JazzBand") type band.xml
<?xml version="1.0" encoding="UTF-8"?>
<JazzBand>
<Ensemble>
<Music>Jazz</Music>
<BandName>Kool Katz</BandName>
<Instrumentation>
<Instrument type="wind">
<Text>Trumpet</Text>
</Instrument>
<Instrument type="percussion">
<Text>Piano</Text>
<pianotype>concert grand</pianotype>
</Instrument>
<Instrument type="percussion">
<Text>Drums</Text>
<drumkit>Bass drum</drumkit>
<drumkit>Floor tom</drumkit>
<drumkit>Snare drum</drumkit>
<drumkit>Hi-hat</drumkit>
<drumkit>Ride cymbal</drumkit>
</Instrument>
<Instrument type="string">
<Text>Bass</Text>
<basstype>upright</basstype>
</Instrument>
</Instrumentation>
</Ensemble>
<Musicians>
<Name role="trumpeter">
<Text>Miles</Text>
</Name>
<Name role="vocalist">
<Text>Roger</Text>
</Name>
<Name role="pianist">
<Text>Diana</Text>
</Name>
<Name role="drummer">
<Text>George</Text>
</Name>
<Name role="bassist">
<Text>John</Text>
</Name>
</Musicians>
</JazzBand>
Укажите имена полей в структуре входа для записи в качестве атрибутов в выход XML- файла.
Чтение файла music.xml как структура S. Добавьте суффикс "_att" к именам полей структуры output, которые соответствуют атрибутам в вход XML- файлу.
S = readstruct("music.xml", "AttributeSuffix", "_att")
S = struct with fields:
Ensemble: [1x1 struct]
Musicians: [1x1 struct]
Все элементы в S которые имеют связанные атрибуты, будут иметь суффикс "_att" добавлено к именам атрибутов.
Запросите поле Musicians для просмотра его содержимого. Musicians - структура, содержащая пять структур, каждая из которых содержит поле с именем Name со связанным атрибутом, вызываемым role.
S.Musicians.Name
ans=1×5 struct array with fields:
role_att
Text
Запись S в XML-файл с именем band.xml и отобразить его содержимое. Суффикс "_att" был добавлен к именам атрибутов в файле.
writestruct(S,"band.xml") type band.xml
<?xml version="1.0" encoding="UTF-8"?>
<struct>
<Ensemble>
<Music>Jazz</Music>
<BandName>Kool Katz</BandName>
<Instrumentation>
<Instrument>
<type_att>wind</type_att>
<Text>Trumpet</Text>
</Instrument>
<Instrument>
<type_att>percussion</type_att>
<Text>Piano</Text>
<pianotype>concert grand</pianotype>
</Instrument>
<Instrument>
<type_att>percussion</type_att>
<Text>Drums</Text>
<drumkit>Bass drum</drumkit>
<drumkit>Floor tom</drumkit>
<drumkit>Snare drum</drumkit>
<drumkit>Hi-hat</drumkit>
<drumkit>Ride cymbal</drumkit>
</Instrument>
<Instrument>
<type_att>string</type_att>
<Text>Bass</Text>
<basstype>upright</basstype>
</Instrument>
</Instrumentation>
</Ensemble>
<Musicians>
<Name>
<role_att>trumpeter</role_att>
<Text>Miles</Text>
</Name>
<Name>
<role_att>vocalist</role_att>
<Text>Roger</Text>
</Name>
<Name>
<role_att>pianist</role_att>
<Text>Diana</Text>
</Name>
<Name>
<role_att>drummer</role_att>
<Text>George</Text>
</Name>
<Name>
<role_att>bassist</role_att>
<Text>John</Text>
</Name>
</Musicians>
</struct>
writestruct(S,"band.xml","AttributeSuffix","_att")
Напишите структуру S снова в XML- файл, на этот раз задав значение "AttributeSuffix" как "_att" для указания имен полей в структуре входа в качестве атрибутов. Отображение содержимого band.xml. Атрибуты в band.xml не имеют суффикса "_att".
type band.xml<?xml version="1.0" encoding="UTF-8"?>
<struct>
<Ensemble>
<Music>Jazz</Music>
<BandName>Kool Katz</BandName>
<Instrumentation>
<Instrument type="wind">
<Text>Trumpet</Text>
</Instrument>
<Instrument type="percussion">
<Text>Piano</Text>
<pianotype>concert grand</pianotype>
</Instrument>
<Instrument type="percussion">
<Text>Drums</Text>
<drumkit>Bass drum</drumkit>
<drumkit>Floor tom</drumkit>
<drumkit>Snare drum</drumkit>
<drumkit>Hi-hat</drumkit>
<drumkit>Ride cymbal</drumkit>
</Instrument>
<Instrument type="string">
<Text>Bass</Text>
<basstype>upright</basstype>
</Instrument>
</Instrumentation>
</Ensemble>
<Musicians>
<Name role="trumpeter">
<Text>Miles</Text>
</Name>
<Name role="vocalist">
<Text>Roger</Text>
</Name>
<Name role="pianist">
<Text>Diana</Text>
</Name>
<Name role="drummer">
<Text>George</Text>
</Name>
<Name role="bassist">
<Text>John</Text>
</Name>
</Musicians>
</struct>
S - Входная структураВходная структура, заданная как структура MATLAB. Структура является типом данных, который группирует связанные данные с помощью контейнеров данных, называемых полями.
Если поле в структуре входа содержит отсутствующее значение или NaN, writestruct запишет содержимое поля в виде пустой строки.
Для получения дополнительной информации о структурах см. struct.
filename - Имя файлаИмя файла для записи, заданное как вектор символов или строковый скаляр. Если filename не существует, тогда функция записи создает файл. Если filename - имя существующего файла, затем функция записи перезаписывает его.
В зависимости от места, в котором вы пишете, filename может принять одну из этих форм.
Местоположение | Форма | ||||||||
|---|---|---|---|---|---|---|---|---|---|
| Текущая папка | Чтобы записать в текущую папку, укажите имя файла в Пример:
'myFile.xml' | ||||||||
Другие папки | Чтобы записать в папку, отличную от текущей папки, укажите полное или относительное имя пути в Пример:
'C:\myFolder\myFile.xml' Пример:
'myFolder\myFile.xml' | ||||||||
Удаленное местоположение | Чтобы записать в удаленное место, задайте единый указатель местоположения ресурса (URL) формы:
В зависимости от вашего удаленного местоположения,
Для получения дополнительной информации см. раздел Работа с удаленными данными. Пример:
|
Задайте необязательные разделенные разделенными запятой парами Name,Value аргументы. Name - имя аргумента и Value - соответствующее значение. Name должны находиться внутри кавычек. Можно задать несколько аргументов в виде пар имен и значений в любом порядке Name1,Value1,...,NameN,ValueN.
'StructNodeName','RootName' задает имя для корневого узла выхода XML- файл.'FileType' - Тип файла'auto' (по умолчанию) | 'xml'Тип файла, заданный как разделенная разделенными запятой парами, состоящая из 'FileType' и одно из следующих значений:
'auto' - Автоматическое обнаружение формата файла для записи из расширения, заданного в filename.
'xml' - Экспортировать содержимое структуры как XML-файл независимо от расширения файла, указанного в filename.
Если вы задаете расширение файла в filename это не .xml, можно задать значение 'FileType' как 'xml' для записи содержимого структуры входа в формате XML.
Пример: 'FileType','xml'
'StructNodeName' - Имя корневого узла выходного XML-файлаИмя корневого узла выхода XML- файл, заданное как разделенная запятой пара, состоящее из 'StructNodeName' и либо вектор символов, либо строковый скаляр, содержащий имя корневого узла, который будет использоваться в выходах. Если вы не задаете StructNodeNameимя корневого узла по умолчанию "struct".
Пример: 'StructNodeName','RootName'
'AttributeSuffix' - Суффикс атрибута'Attribute' (по умолчанию) | символьный вектор | строковый скалярСуффикс атрибута, заданный как разделенная разделенными запятой парами, состоящая из 'AttributeSuffix' и векторы символов или строковый скаляр, указывающий, какие имена полей в структуре входа записывать как атрибуты в выход XML- файл.
Для примера - имя поля AttName_att в вход структуре можно задать 'AttributeSuffix','_att' чтобы указать, что 'AttName' должен быть записан как атрибут в выход XML- файл.
Если вы не задаете 'AttributeSuffix', writestruct по умолчанию используется запись полей с помощью суффикса 'Attribute' как атрибуты в выход XML- файл.
Если атрибут задан как значение 'AttributeSuffix' соответствует суффиксу, добавленному к имени атрибута в структуре входа, суффикс будет удален из имени атрибута в выход XML- файла. Для примера, если вы задаете 'AttributeSuffix','_att', поле в структуре входа с именем MyField_att будет соответствовать атрибуту с именем MyField в XML- файл.
Пример: 'AttributeSuffix','_att'
У вас есть измененная версия этого примера. Вы хотите открыть этот пример с вашими правками?
1. Если смысл перевода понятен, то лучше оставьте как есть и не придирайтесь к словам, синонимам и тому подобному. О вкусах не спорим.
2. Не дополняйте перевод комментариями “от себя”. В исправлении не должно появляться дополнительных смыслов и комментариев, отсутствующих в оригинале. Такие правки не получится интегрировать в алгоритме автоматического перевода.
3. Сохраняйте структуру оригинального текста - например, не разбивайте одно предложение на два.
4. Не имеет смысла однотипное исправление перевода какого-то термина во всех предложениях. Исправляйте только в одном месте. Когда Вашу правку одобрят, это исправление будет алгоритмически распространено и на другие части документации.
5. По иным вопросам, например если надо исправить заблокированное для перевода слово, обратитесь к редакторам через форму технической поддержки.