要求 我想读取一个XML树,用遇到的属性填充我的对象,并在每次运行一个方法后(将其插入我的数据库)。没有指定父母的数量,也没有指定顺序,例如,地址 - 死亡 - 死亡 - 地址 - 地址
输入文件
概述:
<Root>
<Element>
<Element2>
<Parent>
<Child>
<Grandchild>
<Grandchild>
</Child>
</Parent>
</Element2>
</Element1>
</Root>
完整示例:
<?xml version="1.0" encoding="utf-8" ?>
<Root>
<Element1>
<Element2>
<Parent>
<Child>
<Grandchild>
<number>01</number>
<name>Person</name>
<Rows>
<Row>
<number>0110</number>
<name>ID</name>
<value>123456789</value>
</Row>
</Rows>
</Grandchild>
<Grandchild>
<number>08</number>
<name>Address</name>
<Rows>
<Row>
<number>1110</number>
<name>street</name>
<value>first aveneu</value>
</Row>
<Row>
<number>1120</number>
<name>streetnumber</name>
<value>345</value>
</Row>
<Row>
<number>1130</number>
<name>zip</name>
<value>2938PS</value>
</Row>
<Row>
<number>1160</number>
<name>country</name>
<value>Germany</value>
</Row>
</Rows>
</Grandchild>
</Child>
</Parent>
<Parent>
<Child>
<Grandchild>
<number>01</number>
<name>Person</name>
<Rows>
<Row>
<number>0110</number>
<name>ID</name>
<value>987654321</value>
</Row>
</Rows>
</Grandchild>
<Grandchild>
<number>06</number>
<name>Death</name>
<Rows>
<Row>
<number>0810</number>
<name>date</name>
<value>2012-01-03</value>
</Row>
<Row>
<number>0820</number>
<name>placeOfDeath</name>
<value>attic</value>
</Row>
<Row>
<number>0830</number>
<name>funeral</name>
<value>burrial</value>
</Row>
</Rows>
</Grandchild>
</Child>
</Parent>
</Element2>
</Element1>
</Root>
期望的结果 在遇到父母确定孙子的类型之后(6号是死亡号码8是地址)每个父母总是有孙子号码1'人',第二个孙子是死亡或地址。
阅读第一位父母
Person person = new Person();
person.ID = value; <--- filled with 123456789
person.street = value; <--- filled with first aveneu
person.streetnumber = value; <--- filled with 345
person.zip = value; <--- filled with 2938PS
person.country = value; <--- filled with germany
person.DoMethod(); // inserts the value in db
继续阅读下一位家长。
Person person = new Person();
person.ID = value; <--- filled with 987654321
person.date = value; <--- filled with 2012-01-03
person.placeOfDeath = value; <--- filled with attic
person.funeral = value; <--- filled with burrial
person.DoMethod(); // insert the values in db
继续阅读,直到没有父母找到
编辑:如何针对每个孩子定位第二个孙子的名字元素?喜欢地址或死亡
代码/信用
在Daniel Hilgarth的帮助下,我没有得到更多:Linq to XML (C#) parse XML tree with no attributes/id to object XML树已经改变了,我真的被卡住了......与此同时我尝试发布新的工作代码......
答案 0 :(得分:0)
可以按照丹尼尔在你提到的问题中提出的方式来完成。您需要为每个Row
节点的name
节点(value
和Child
节点的值)创建字典,然后迭代这些键值对以填写Person
个实例:
var doc = XDocument.Parse(xml);
var children = doc.Descendants("Child")
.Select(c => c.Descendants("Row")
.ToDictionary(
r => r.Element("name").Value,
r => r.Element("value").Value
)
);
foreach (var child in children)
{
Person person = new Person();
foreach (var key in child.Keys)
{
switch (key)
{
case "ID":
person.ID = int.Parse(child[key]);
break;
case "street":
person.street = child[key];
break;
case "streetnumber":
person.streetnumber = child[key];
break;
case "zip":
person.zip = child[key];
break;
case "country":
person.country = child[key];
break;
case "date":
person.date = DateTime.Parse(child[key]);
break;
case "placeOfDeath":
person.placeOfDeath = child[key];
break;
case "funeral":
person.funeral = child[key];
break;
default:
break;
}
}
person.DoMethod();
}