我有这样的XML文件,我想读取ID,短名称,名称节点值。
<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<AccountingUnitList xmlns="http://www.google.com">
<AccountingUnit>
<ID>17406</ID>
<ShortName>test</ShortName>
<Name>test</Name>
</AccountingUnit>
<AccountingUnit>
<ID>18006</ID>
<ShortName>ANOTHERtest</ShortName>
<Name>Anothertest</Name>
</AccountingUnit>
<AccountingUnit>
<ID>18046</ID>
<ShortName>RKU</ShortName>
<Name>hospital</Name>
</AccountingUnit>
<AccountingUnit>
<ID>18047</ID>
<ShortName>MNU</ShortName>
<Name>MNU</Name>
</AccountingUnit>
</AccountingUnitList>
递归读取Node元素的最佳方法是什么?
这就是我尝试读取节点值的方法:
var accountingunit = (
from e in XDocument.Parse(textresult).Root.Elements("AccountingUnit")
select new node
{
idvalue = (string)e.Element("ID"),
shortname =(string)e.Element("ShortName"),
name = (string)e.Element("Name"),
});
foreach(var unit in accountingunit)
{
Console.WriteLine("ID"+ unit.idvalue + unit.name + unit.shortname);
}
这是节点consructor:
public class node
{
public string idvalue { get; set; }
public string shortname { get; set; }
public string name { get; set; }
}
答案 0 :(得分:14)
您的文档中有一个xml命名空间。AccountingUnitList
的所有子元素都继承了命名空间,因此您需要通过元素名称指定它:
XNamespace ns = "http://www.google.com";
var accountingunit = (
from e in XDocument.Parse(textresult).Elements(ns + "AccountingUnit")
select new node
{
idvalue = (string)e.Element(ns + "ID"),
shortname =(string)e.Element(ns + "ShortName"),
name = (string)e.Element(ns + "Name"),
});