Чтобы считать XML-файл из вашего локального диска или из URL, используйте функцию xmlread
. xmlread
возвращает содержимое файла в узле Объектной модели документа (DOM). Для получения дополнительной информации см.:
В Объектной модели документа каждый элемент в XML-файле соответствует узлу. Свойства и методы для узлов DOM (то есть, путь вы создаете и узлы доступа) следуют нормам, установленным консорциумом Всемирной паутины.
Например, рассмотрите этот демонстрационный XML-файл:
<productinfo xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="https://www.mathworks.com/namespace/info/v1/info.xsd"> <!-- This is a sample info.xml file. --> <list> <listitem> <label>Import Wizard</label> <callback>uiimport</callback> <icon>ApplicationIcon.GENERIC_GUI</icon> </listitem> <listitem> <label>Profiler</label> <callback>profile viewer</callback> <icon>ApplicationIcon.PROFILER</icon> </listitem> </list> </productinfo>
Информация в картах файлов к следующим типам узлов в DOM:
Узлы элемента — Соответствуют именам тега. В демонстрационном файле info.xml
эти теги соответствуют узлам элемента:
productinfo
list
listitem
label
callback
icon
В этом случае элементом list
является parent элемента listitem
узлы child. Элемент productinfo
является узлом элемента root.
Text nodes — Содержит значения, сопоставленные с узлами элемента. Каждый текстовый узел является дочерним элементом узла элемента. Например, текстовый узел Import Wizard
является дочерним элементом первого узла элемента label
.
Attribute nodes — Содержит имя и пары значения, сопоставленные с узлом элемента. Например, xmlns:xsi
является именем атрибута, и http://www.w3.org/2001/XMLSchema-instance
является своим значением. Узлы атрибута не являются родительскими элементами или дочерними элементами никаких узлов.
Comment nodes — Включает дополнительный текст в файл, в форму <!--Sample comment-->
.
Document nodes — Соответствует целому файлу. Используйте методы на узле документа, чтобы создать новый элемент, текст, атрибут или узлы комментария.
Для полного списка методов и свойств узлов DOM, см. описание пакета org.w3c.dom
в https://docs.oracle.com/javase/7/docs/api
.
Полный файл
содержит несколько элементов matlabroot/toolbox/matlab/general/info.xml
listitem
, таких как:
<listitem> <label>Import Wizard</label> <callback>uiimport</callback> <icon>ApplicationIcon.GENERIC_GUI</icon> </listitem>
Один из элементов label
имеет дочерний текст Plot Tools
. Предположим, что вы хотите найти текст для элемента callback
в том же listitem
. Выполните эти шаги:
Инициализируйте свои переменные и вызовите xmlread
, чтобы получить узел документа:
findLabel = 'Plot Tools'; findCbk = ''; xDoc = xmlread(fullfile(matlabroot, ... 'toolbox','matlab','general','info.xml'));
Найдите все элементы listitem
. Метод getElementsByTagName
возвращает глубокий список, который содержит информацию о дочерних узлах:
allListitems = xDoc.getElementsByTagName('listitem');
Списки, возвращенные методами DOM, используют основанную на нуле индексацию.
Для каждого listitem
сравните текст для элемента label
к тексту, который вы хотите найти. Когда вы определяете местоположение правильного label
, получаете текст callback
:
for k = 0:allListitems.getLength-1 thisListitem = allListitems.item(k); % Get the label element. In this file, each % listitem contains only one label. thisList = thisListitem.getElementsByTagName('label'); thisElement = thisList.item(0); % Check whether this is the label you want. % The text is in the first child node. if strcmp(thisElement.getFirstChild.getData, findLabel) thisList = thisListitem.getElementsByTagName('callback'); thisElement = thisList.item(0); findCbk = char(thisElement.getFirstChild.getData); break; end end
Отобразите конечные результаты:
if ~isempty(findCbk) msg = sprintf('Item "%s" has a callback of "%s."',... findLabel, findCbk); else msg = sprintf('Did not find the "%s" item.', findLabel); end disp(msg);
Для дополнительного примера, который создает массив структур, чтобы хранить данные от XML-файла, смотрите страницу ссылки на функцию xmlread
.