我有一个我需要解析的xml消息(无格式控制),看起来像我需要处理的下面(Name / Value Pairs)。查询Name = x和获取相关值的值的最佳方法是什么?
我目前正在使用嵌套选择来尝试从特定的名称/值对中获取值。只是想知道我是否可以使用更简单的LINQ / Lambda调用。
任何建议将不胜感激。
<Message>
<MessageContent>
<MessageDetails>
<Name>System_ID</Name>
<Value>12345</Value>
</MessageDetails>
<MessageDetails>
<Name>System_Name</Name>
<Value>Test System</Value>
</MessageDetails>
</MessageContent>
</Message>
答案 0 :(得分:7)
将Linq用于XML:
var xml = XElement.Load(someXmlFile);
var results = xml.Descendants("MessageDetails")
.Where(m => m.Element("Name").Value == someValue)
.Select(m => m.Element("Value").Value);
如果您只希望一个匹配项添加FirstOrDefault()
以获得第一个匹配值。
根据您的xml判断,您似乎也可以从投影到字典中受益(如果您的Name
元素值是唯一的):
var dictionary = xml.Descendants("MessageDetails")
.ToDictionary(x => x.Element("Name").Value,
x => x.Element("Value").Value);
现在你可以使用字典了:
string value = dictionary["System_ID"];
答案 1 :(得分:0)
如果您无法控制格式,并且以后可能会更改,我也会考虑using XPath,因此您可以使用较少的代码更改来修改您的选择。例如,获取系统ID的XPath将是:
//MessageContent/MessageDetails[Name='System_Name']/Value