3

Я обнаружил, что 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 ответ1

4

Прежде всего, существуют определенные атрибуты типа данных XSD, которые не поддерживаются в Excel. Вы можете увидеть полный список здесь.

Чтобы заставить Excel правильно связать XSD с соответствующим XML-файлом, вам нужно будет создать карту XML, а затем тщательно сопоставить все элементы XML, как подробно описано здесь.

Честно говоря, я бы посоветовал вам использовать правильный редактор XML и избавить себя от головной боли. :)

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .