DataTable ReadXmlSchema и ReadXml, приводящие к ошибке - PullRequest
0 голосов
/ 08 апреля 2010

У меня возникли проблемы с методами ReadXmlSchema и ReadXml для DataTable. Я получаю сообщение об ошибке «DataTable не поддерживает вывод схемы из Xml».

Фрагмент кода: Я пробовал

Table.ReadXmlSchema(new StringReader(File.ReadAllText(XsdFilePath)));
Table.ReadXml(new StringReader(File.ReadAllText(XmlFilePath)));

И

Table.ReadXmlSchema(XsdFilePath);
Table.ReadXml(XmlFilePath);

Фрагмент XML:

<ScreenSets>
  <ScreenSet id="Credit 1">
    <Screen xmlFile="sb-credit1.en.xml" tabText="Recommendation" isCached="false">
      <Buttons>
        <Button id="btnClosePresentation"/>
      </Buttons>
    </Screen>
  </ScreenSet>
  <ScreenSet id="Credit 2">
    <Screen xmlFile="sb-credit2.en.xml" tabText="Recommendation" isCached="false">
      <Buttons>
        <Button id="btnClosePresentation"/>
      </Buttons>
    </Screen>
  </ScreenSet>
  <ScreenSet id="Credit 3">
    <Screen xmlFile="sb-credit3.en.xml" tabText="Recommendation" isCached="false">
      <Buttons>
        <Button id="btnClosePresentation"/>
      </Buttons>
    </Screen>
  </ScreenSet>
</ScreenSets>

XSD:

<?xml version="1.0" encoding="utf-8"?>
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
  <xs:element name="ScreenSets">
    <xs:complexType>
      <xs:sequence>
        <xs:element maxOccurs="unbounded" name="ScreenSet">
          <xs:complexType>
            <xs:sequence>
              <xs:element name="Screen">
                <xs:complexType>
                  <xs:sequence>
                    <xs:element name="Buttons">
                      <xs:complexType>
                        <xs:sequence>
                          <xs:element maxOccurs="unbounded" name="Button">
                            <xs:complexType>
                              <xs:attribute name="id" type="xs:string" use="required" />
                            </xs:complexType>
                          </xs:element>
                        </xs:sequence>
                      </xs:complexType>
                    </xs:element>
                  </xs:sequence>
                  <xs:attribute name="xmlFile" type="xs:string" use="required" />
                  <xs:attribute name="tabText" type="xs:string" use="required" />
                  <xs:attribute name="isCached" type="xs:boolean" use="required" />
                </xs:complexType>
              </xs:element>
            </xs:sequence>
            <xs:attribute name="id" type="xs:string" use="required" />
          </xs:complexType>
        </xs:element>
      </xs:sequence>
    </xs:complexType>
  </xs:element>
</xs:schema>

Ответы [ 3 ]

1 голос
/ 22 июня 2011

Попробуйте вместо этого использовать DataSet и извлечь DataTable из набора данных
Пример:

XML = @"
<Records>
  <Record>
    <Col1>0</Col1>
    <Col2>ABC</Col2>
  </Record>
  <Record>
    <Col1>1</Col1>
    <Col2>CDE</Col2>
  </Record>
</Records>";

DataSet DS = new DataSet();
DS.ReadXml(new StringReader(XML));

DataTable DT=DS.Tables["Records"];
1 голос
/ 08 апреля 2010

Ваша схема и данные не представляют собой одну таблицу и имеют формат, который не распознается объектами данных .net, такими как DataSet и DataTable.

Лучше всего разработать набор данных в конструкторе, а затем вызвать dataset.WriteXmlSchema / Data, чтобы получить образец .xsd.

0 голосов
/ 12 мая 2010

Если вы хотите, чтобы XML-файл из базы данных вы могли использовать, dataset.WriteXml ("filepath", XmlWriteMode.WriteSchema)

Затем, чтобы прочитать файл в таблицу, dataset.ReadXml ("filepath", XmlReadMode.ReadSchema) таблица = dataset.tables (0)

При условии, что вы заполнили схему таблицы до схемы xmlfileschema.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...