4

所以基本上,我正在阅读两个 XML 文档。第一个有两个需要存储的值:名称和值。第二个有四个值:Name、DefaultValue、Type 和 Limit。在阅读文档时,我想将每个存储到某个对象中。然后,我需要能够将这两个对象组合成一个对象,其中存储了 5 个值。XML 文档的长度不同,但第二个文档的大小始终至少是第一个文档的大小。

例子:

<XML1>
  <Item1>
    <Name>Cust_No</Name>
    <Value>10001</Value>
  </Item1>
  <Item4>
    ITEM4 NAME AND VALUE
  </Item4>
  <Item7>
    ITEM 7 NAME AND VALUE
  </Item7>
</XML1>

<XML2>
  <Item1>
    <Name>Cust_No</Name>
    <DefaultValue></DefaultValue>
    <Type>varchar</Type>
    <Limit>15</Limit>
  </Item1>
  6 MORE TIMES ITEMS 2-7
</XML2>

我已经有通过 XML 循环的代码。我真的只需要思考什么是存储数据的最佳方式而已。最终,我希望能够在 Name Key 上加入这两个对象。我尝试了string[]and arrayList[],但我遇到了组合它们的困难。我也阅读了Dictionary,但也很难实现(我以前从未使用Dictionary过)。

4

1 回答 1

2

这是 Linq to Xml 查询,它将连接两个 XDocument 并为连接的项目选择匿名对象。每个对象将有五个属性:

var query = 
  from i1 in xdoc1.Root.Elements()
  join i2 in xdoc2.Root.Elements()
      on (string)i1.Element("Name") equals (string)i2.Element("Name") into g
  let j = g.SingleOrDefault() // get joined element from second file, if any
  select new {
      Name = g.Key,
      Value = (int)i1.Element("Value"),
      DefaultValue = (j == null) ? null : (string)j.Element("DefaultValue"),
      Type = (j == null) ? null : (string)j.Element("Type"),
      Limit = (j == null) ? null : (string)j.Element("Limit")
  };

像这样创建的 XDocuments:

var xdoc1 = XDocument.Load(path_to_xml1);
var xdoc2 = XDocument.Load(path_to_xml2);

查询的用法:

foreach(var item in query)
{
   // use string item.Name
   // integer item.Value
   // string item.DefaultValue
   // string item.Type
   // string item.Limit
}
于 2013-02-20T17:52:49.707 回答