GetElementsByTagName只获取第一个节点(XMLDocument)

时间:2016-08-05 10:48:06

标签: c# xml xml-parsing xmldocument getelementsbytagname

这是我的代码:

FileInfo[] Files = difo.GetFiles("*.xml");            
        string[] parts;
        string[] FileSearchRes = Directory.GetFiles(@"C:\Users\ahodhv\Perforce\ahodhv_RD0029717_1921\prod\delivery\q_rec\int_test\SOPS", "*.xml", SearchOption.AllDirectories);
        int i = 0;
        foreach (FileInfo File in Files)

        {
            parts = File.Name.Split('_');                                             
            boxvehicles.Items.Add(parts[0]);
            string test = FileSearchRes[i];
            doc.Load(FileSearchRes[i]);
            List<string> name = new List<string>();
            var accountNodes = doc.GetElementsByTagName("FpcBlock");
            for (int j = 0; j < accountNodes.Count; j++)
            {
                var account = accountNodes[j].SelectSingleNode("./FPC");
                if (account != null && account.Attributes != null)
                {
                    // Read node attribute
                    name.Add(account.Attributes["Name"].Value + account.Attributes["Value"].Value);
                }
            }
                i++;            
        }

我试图从一个看起来像这样的xml文件中读取:

<FpcBlock Version="01">
        <FPC Name="1" Value="A" Updated="false" />
        <FPC Name="3" Value="B" Updated="false" />
        <FPC Name="5" Value="B" Updated="false" />
        <FPC Name="8" Value="B" Updated="false" />
        <FPC Name="10" Value="B" Updated="false" />
</FpcBlock>

问题在于:

var accountNodes = doc.GetElementsByTagName("FpcBlock");

帐户节点的计数为1,这是不正确的,因为我有更多的节点。因此,只有第一个节点被添加到名称。我做错了什么?

编辑:对不起,如果我很困惑。我想保存列表中的所有行。我想要的是列表应该是这样的:

1A
3B
5B

等等。所以我保存了名称和价值。但目前我只得到第一排是1A。

编辑nr 2: 我误解了GetElementsByTagName()方法。通过更改为GetElementsByTagName("FPC")它应该是问题。

1 个答案:

答案 0 :(得分:0)

您正在查询名为FpcBlock的元素,但似乎期待名为FPC的元素。如果你改变以寻找你实际想要找到的元素,那么你可能会发现问题消失了。

也就是说,LINQ to XML是比现有的XmlDocument API更现代,更清晰的API。使用它会更好:

var nameValues = 
    from fpc in doc.Descendants("FPC")
    select new
    {
        Name = (int) fpc.Attribute("Name"),
        Value = (string) fpc.Attribute("Value")
    };

有关正常工作的演示,请参阅this fiddle