如何使用LINQ解析这个XML
本文关键字:XML 何使用 LINQ | 更新日期: 2023-09-27 18:05:41
我有以下XML:
<propertyMetrics month="12" year="2013" propertyId="3923837">
<metric name="siteTotal" uom="kBtu" dataType="numeric">
<value>409249.0</value>
</metric>
<metric name="waterUseTotal" uom="kgal" dataType="numeric">
<value>2434.2</value>
</metric>
<metric name="totalGHGEmissions" uom="MtCO2e" dataType="numeric">
<value>28.5</value>
</metric>
<metric name="greenPowerOnSite" dataType="numeric">
<value xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:nil="true" />
</metric>
</propertyMetrics>
我想要的是关闭"name"属性并获得与该名称关联的"value"answers"uom"。我正在努力想出一个简单的方法来做这件事。什么好主意吗?
未经测试,我不确定最后的'null'值,但它给出了获得它作为Dictionary<string, anonymous>
的基本想法
var doc = XElement.Load(fileName);
var data = dox.Descendants("metric")
.ToDictionary(e => e.Attribute("name").Value,
e => new { uom = e.Attribute("uom").Value, value =(double?) e.Element("Value") });