繁体   English   中英

使用Linq-to-Xml和几个循环读取几个元素?

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM