如何使用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"。我正在努力想出一个简单的方法来做这件事。什么好主意吗?

如何使用LINQ解析这个XML

未经测试,我不确定最后的'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") });