【发布时间】:2017-02-17 02:57:43
【问题描述】:
我正在尝试使用 Linq To XML 读取 XML 文件,但似乎无法理解如何操作。
我有这个 XML 文件:
<?xml version="1.0" encoding="utf-8" ?>
<Thing>
<Objects>
<MyTag name="" num="2">
<Date month="May" day="2" year="2006" />
</MyTag>
<MyTag name="" num="4">
<Date month="May" day="22" year="2012" />
</MyTag>
<MyTag name="" num="2">
<Date month="May" day="11" year="2034" />
</MyTag>
</Objects>
</Thing>
我从这个查询开始:
// Load the xml
XDocument document = XDocument.Load(XML_PATH);
var query = from thing in document.Root.Descendants("Objects")
select new
{
TagName = thing.Attribute("name").Value.ToString(),
TagNum = thing.Attribute("num").Value.ToString(),
// What do I write here to get the Date tag and attributes?
};
如何获得Date 标记和属性?不知道如何获得下一个节点。
我试图在foreach 循环中打印出TagName 和TagNum,如下所示:
foreach(string value in query)
{
Console.WriteLine(value.TagName + " " + value.TagNum);
}
但是,我收到一个错误提示
CS0030 Cannot convert type '<anonymous type: string TagName, string TagNum>' to 'string'
【问题讨论】:
-
使用
foreach (var value in query)