Открытие файлов XML+XSD в Microsoft Excel 2013
Я обнаружил, что Excel 2013 поддерживает открытие, редактирование и сохранение файлов XML. Я создал файл XML + XSD, который Excel открывает без нареканий и ошибок. (Т.е. он не утверждает, что должен создавать схему из источника данных XML)
Тем не менее, Excel по-прежнему не соблюдает, например, настройки ограничений в файле.XSD. Есть ли способ сделать это в Excel? (Я знаю, что Excel не является редактором XML, поэтому я полностью согласен, если это невозможно.)
файл data.xsd:
<?xml version="1.0"?>
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="http://example.com" elementFormDefault="qualified">
<xs:element name="data">
<xs:complexType>
<xs:sequence>
<xs:element name="item" minOccurs="0" maxOccurs="unbounded">
<xs:complexType>
<xs:all>
<xs:element name="title" type="xs:string" minOccurs="0" maxOccurs="1">
</xs:element>
<xs:element name="type" minOccurs="0" maxOccurs="1">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:enumeration value="header"/>
<xs:enumeration value="normal"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
<xs:element name="backgroundcolor" minOccurs="0" maxOccurs="1">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:pattern value="#[0-9A-Fa-f]+"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
<xs:element name="fontcolor" minOccurs="0" maxOccurs="1">
<xs:simpleType>
<xs:restriction base="xs:string">
<xs:pattern value="#[0-9A-Fa-f]+"/>
</xs:restriction>
</xs:simpleType>
</xs:element>
</xs:all>
</xs:complexType>
</xs:element>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
файл test.xml:
<?xml version="1.0" encoding="UTF-8"?>
<j:data xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://example.com data.xsd" xmlns:j="http://example.com">
<j:item>
<j:title>test title</j:title>
<j:backgroundcolor>#aaf8941e</j:backgroundcolor>
<j:fontcolor>#ffffff</j:fontcolor>
<j:type>header</j:type>
</j:item>
</j:data>
1 ответ
Прежде всего, существуют определенные атрибуты типа данных XSD, которые не поддерживаются в Excel. Вы можете увидеть полный список здесь.
Чтобы заставить Excel правильно связать XSD с соответствующим XML-файлом, вам нужно будет создать карту XML, а затем тщательно сопоставить все элементы XML, как подробно описано здесь.
Честно говоря, я бы посоветовал вам использовать правильный редактор XML и избавить себя от головной боли.:)