[英]Reading several elements using Linq-to-Xml and some loop?
通过以下代码,我目前正在阅读每个<nv>
<ns>CounterSales</ns>
(第三个元素),这很棒。 我包括代码和XML。
这是代码,如果ElementAt
是硬编码的,则效果很好:
var xDoc = XDocument.Parse(xmlStr);
var nvs = xDoc.Descendants("nv");
var nads = nvs.Select(nv => nv.Elements("nad").First().Value).ToList();
var thirdRs = nvs.Select(nv => nv.Elements("r").ElementAt(2).Value).ToList();
这是xmlStr
的值:
<ni>
<nss>20150927</nss>
<gp>Addon</gp>
<ns>CounterBlah1</ns>
<ns>CounterBlah2</ns>
<ns>CounterSales</ns>
<ns>CounterBlah4</ns>
<ns>CounterBlah5</ns>
<ns>CounterBlah6</ns>
<nv>
<nad>Style=1,Rfu=1,Id=132</nad>
<r>0</r>
<r>15</r>
<r>8</r>
<r>3</r>
<r>2</r>
<r>2</r>
</nv>
<nv>
<nad>Style=1,Rfu=1,Id=433</nad>
<r>0</r>
<r>15</r>
<r>30</r>
<r>3</r>
<r>2</r>
<r>2</r>
</nv>
<nv>
<nad>Style=1,Rfu=1,Id=665</nad>
<r>0</r>
<r>15</r>
<r>90</r>
<r>3</r>
<r>2</r>
<r>2</r>
</nv>
</ni>
但是,假设我想阅读多个计数器。 我有一个数据表,当前有两行: [CounterSales]
和[CounterBlah5]
。 我想以相同的方式处理其他两个计数器:
int index = 0;
DataTable results = GetCounters();
//results has two rows: [CounterSales] & [CounterBlah5]
foreach (DataRow row in results.Rows)
{
string counter = cellRow["counter"]; //counter equals "CounterSales"
/* Iterate through all <ns> to see where "CounterSales" is located.
In this case, index = 2. On next foreach, index equals 4 */
var xDoc = XDocument.Parse(xmlStr);
var nvs = xDoc.Descendants("nv");
var nads = nvs.Select(nv => nv.Elements("nad").First().Value).ToList();
var thirdRs = nvs.Select(nv => nv.Elements("r").ElementAt(index).Value).ToList();
}
任何帮助表示赞赏。
谢谢。
如果我正确理解了您的问题,这就是您所需要的
DataTable results = GetCounters();
//results has two rows: [CounterSales] & [CounterBlah5]
foreach (DataRow row in results.Rows)
{
string counter = cellRow["counter"]; //counter equals "CounterSales"
/* Iterate through all <ns> to see where "CounterSales" is located.
In this case, index = 2. On next foreach, index equals 4 */
var xDoc = XDocument.Parse(xmlStr);
//here we find the index
var requiredIndex = xDoc.Descendants("ns")
.Select((node, idx) => new { node, idx})
.First(x => x.node.Value.Equals(counter)).idx;
var nvs = xDoc.Descendants("nv");
var nads = nvs.Select(nv => nv.Elements("nad").First().Value).ToList();
var thirdRs = nvs.Select(nv => nv.Elements("r").ElementAt(requiredIndex).Value).ToList();
}
编辑 :从本文中查找List<T>
索引的较短语法。
var requiredIndex = xDoc.Descendants("ns").ToList().FindIndex(x => x.Value == counter);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.