在运行时从DataTable向XDocument添加元素

本文关键字:XDocument 添加 元素 DataTable 运行时 | 更新日期: 2023-09-27 18:04:53

我试图通过在运行时从DataTable提取数据来使用XDocument生成XML。我想要这样的输出格式:

<Document>
  <Alphabets>
    <Data>
      <Capital>AAA</Capital>
      <Small>aaa</Small>
    </Data>    
  </Alphabets>
  <Language>
      <Name>English</Name>
  </Language>
  <Alphabets>
    <Data>
      <Capital>BBB</Capital>
      <Small>bbb</Small>
    </Data>
  </Alphabets>
  <Language>
      <Name>English</Name>
  </Language>
</Document>

Language元素必须出现在每个Alphabets元素之后。我已经非常努力地实现了这一点,但我无法将这个Alphabets标签放在每个Language元素之后。我所取得的成就是这样的,其中Language元素落在Alphabets元素:

<Document>
  <Alphabets>
    <Data>
      <Capital>AAA</Capital>
      <Small>aaa</Small>
    </Data>
    <Language>
      <Name>English</Name>
    </Language>
  </Alphabets>
  <Alphabets>
    <Data>
      <Capital>BBB</Capital>
      <Small>bbb</Small>
    </Data>
    <Language>
      <Name>English</Name>
    </Language>
  </Alphabets>
</Document>  
下面是我的代码:
        static void Main(string[] args)
        {
            DataTable dtAlpha = new DataTable("Alphabetss");
            dtAlpha.Columns.Add("Capital", typeof(string));
            dtAlpha.Columns.Add("Small", typeof(string));
            dtAlpha.Rows.Add("AAA", "aaa");
            dtAlpha.Rows.Add("BBB", "bbb");
            XDocument doc = new XDocument(
                new XDeclaration("1.0", "UTF-8", null),
                new XElement("Document",
                        from row in dtAlpha.AsEnumerable()
                        select new XElement("Alphabets",
                            new XElement("Data",
                                new XElement("Capital", row.Field<string>("Capital")),
                                new XElement("Small", row.Field<string>("Small"))
                                         ),
                        new XElement("Language",
                            new XElement("Name", "English")
                            )))
                            );
            Console.WriteLine(doc.ToString());
            Console.ReadKey();
        }  

请帮帮我。

在运行时从DataTable向XDocument添加元素

您可以这样尝试:

XDocument doc = new XDocument(
    new XDeclaration("1.0", "UTF-8", null),
    new XElement("Document")
);
foreach(var row in dtAlpha.AsEnumerable())
{
    var alphabets = new XElement("Alphabets",
                        new XElement("Data",
                            new XElement("Capital", row.Field<string>("Capital")),
                            new XElement("Small", row.Field<string>("Small"))
                        )
                    );
    var language = new XElement("Language",
                        new XElement("Name", "English")
                    );
    doc.Root.Add(alphabets);
    doc.Root.Add(language);
}