在C#中,如何使用LINQ从XML文件中选择值?
这是我的XML文件:
<?xml version="1.0" encoding="utf-8"?>
<Level1>
<Level2>
<Value1>This-is-value-1</Value1>
<Value2>This-is-value-2</Value2>
<Value3>This-is-value-3</Value3>
<Value4>This-is-value-4</Value4>
</Level2>
</Level1>
这是我到目前为止的代码:
var doc = XDocument.Load(filename);
var values = from lv1 in doc.Descendants("level1")
from lvl2 in lv1.Descendants("Level2")
select new {
Value1 = lv1.Attribute("Value1").Value,
Value2 = lv1.Descendants("Value2").Value,
Value3 = lv1.Descendants("Value3").Value,
Value4 = lv1.Descendants("Value4").Value,
};
我想要检索以下值:
我可以请一些帮助让这个工作吗?
修改
抱歉,我想补充说我想将这些值放在本地字段中。
E.g。以下是字段名称:
string Value1;
string Value2;
string Value3;
string Value4;
我可以帮助将LINQ语句中的值放入本地字段吗?
答案 0 :(得分:6)
您当前的代码存在各种问题:
Attribute
Value
上的Descendants
属性,但Descendants
返回IEnumerable<XElement>
lv2
level1
作为元素名称而不是Level1
。 (XML区分大小写。)我怀疑你只是想要:
var doc = XDocument.Load(filename);
var values = from level in doc.Descendants("Level1").Descendants("Level2")
select new {
Value1 = (string) level.Element("Value1"),
Value2 = (string) level.Element("Value2"),
Value3 = (string) level.Element("Value3"),
Value4 = (string) level.Element("Value4")
};