这是我的代码:
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")
它应该是问题。
答案 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。