LINQ to Dictionary - Using XML



我已经问了一个模拟问题,当然,这个是不同的,我已经尝试过了。

我尝试使用 Linq 读取 XML 数据并解决了这个问题,但是,我需要选择多个值并将其存储到字典中。我已经尝试过(评论是我的尝试),但我就是无法弄清楚并得到如下错误:

System.NullReferenceException:对象引用未设置为对象的实例 在DSDSDSDSDS。MainClass+c__AnonStorey0.<>m__0 (System.Xml.Linq.XElement datanum) [0x00000] in/Users/p/Projects/dsdsdsdsds/dsdsdsds/Main.cs:23

假设我的 XML 文件如下所示:

<?xml version="1.0" encoding="UTF-8"?>
   <kml xmlns="http://www.opengis.net/kml/2.2">
     <Document>
       <name>My word place</name>
         <Placemark>
           <name>Main Building</name> 
             <id>1</id>
               <Polygon>
            <extrude>1</extrude>
         <altitudeMode>relativeToGround</altitudeMode>
       <outerBoundaryIs>
    <LinearRing>
 <coordinates>

现在我需要得到的是"名称"和"id",并将这些值放入字典中。

这是我的代码:

var xdoc = XDocument.Load ("buildings.kml");
        XNamespace kml = "http://www.opengis.net/kml/2.2";
        var dict = xdoc.Descendants(kml + "Placemark").ToDictionary (
            datanum => datanum.Attribute(kml + "name").Value,
            datanum => datanum.Attribute(kml + "id").Value );
            /*.ToDictionary(e => e.Element("name").Value,
                                 e => e.Descendants("id")
                                    .Select (item => new Building
                                    {
                                        BuildingName = (string) e.Element(kml + "name").Value,
                                        BuildingID = Convert.ToInt16(item.Element(kml + "id").Value)
                                    }).ToList()
                                    );
        /*
        /*var buildings = xdoc.Descendants (kml + "Placemark")
            .Select((element, index) => new Building {
                BuildingName = (string) element.Element(kml + "name"),
                BuildingID = (int) element.Element(kml + "id")
            });
        */

注意:我已经进行了三次尝试,但是,收到相同/相似的错误消息。

nameid元素,而不是属性。因此,您需要使用 Element() 而不是 Attribute()

var dict = xdoc.Descendants(kml + "Placemark")
               .ToDictionary(datanum => datanum.Element(kml + "name").Value,
                             datanum => datanum.Element(kml + "id").Value);

如果 nameid 是可选标记,则可以使用以下代码来避免NullReferenceException

var dict = doc.Descendants(kml + "Placemark")
              .Select(x => new { name = (string)x.Element(kml + "name"),
                                 id = (string)x.Element(kml + "id") })
              .Where(x => x.name != null)
              .ToDictionary(x => x.name, x => x.id);

请注意:这只是忽略没有name标签Placemark标签。 Placemark仅具有name标记且没有id标记的标记仍会被考虑在内。

顺便说一句:您的格式很好地掩盖了这一点,但是您在问题中提供的XML无效。格式正确,这一点变得很明显:

<?xml version="1.0" encoding="UTF-8"?>
<kml xmlns="http://www.opengis.net/kml/2.2">
  <Document>
  <name>My word place</name>
  <Placemark>
    <name>Main Building</name> 
    <id>1</id>
    <Polygon>
      <extrude>1</extrude>
      <altitudeMode>relativeToGround</altitudeMode>
      <outerBoundaryIs>
        <LinearRing>
          <coordinates>

相关内容

  • 没有找到相关文章

最新更新