我有如下的xml:
<Reports>
<report>
<name>By Book</name>
<report_type>book</report_type>
<Object>Count Change</Object>
<Slicers detail="detail">
<Namespace>EOD</Namespace>
<BookNode>HighLevel</BookNode>
<DateFrom>T-2</DateFrom>
<DateTo>T-1</DateTo>
<System>NewSystem</System>
</Slicers>
</report>
</Reports>我只想遍历Xdocument中每个元素的值(首选是Slicers下的任何元素),但只从所有元素开始。
当我运行以下命令时:
var slicers = from c in config.Elements("Reports")
select c.Value ;
foreach (var xe in slicers)
{
Console.WriteLine(xe);
}输出是将所有值连接在一起的单行。
"By BookbookCount ChangeEODHighLevelT-2T-1NewSystem“
我想一次循环一个,首先'By Book‘,运行一些代码,然后book等等。
我确信这很简单,但我无法绕过它。我尝试过foreach(查询中的Xelement),但结果相同
发布于 2012-07-26 20:48:44
我会像这样做;
XmlDocument doc = new XmlDocument();
doc.LoadXml(xml);
//load in your xml here
XmlNodeList xnList = doc.SelectNodes("nodeYou'reLookingFor");
//for getting just the splicers you could do "Reports/report/Slicers"
foreach (XmlNode node in xnList)
string namespace = node["Namespace"].InnerText;
//go through all your nodes here您正在创建一个xmldoc,将xml加载到其中,创建一个包含列表中每个节点的列表(在指定的Xpath处),然后遍历每个节点。在循环中,您可以通过引用
node["nodenamehere"].InnerTexthttps://stackoverflow.com/questions/11667536
复制相似问题