跳过读取某个父节点内的xml元素

时间:2012-05-01 17:53:43

标签: c# .net xml kml

我正在使用xmlreader.read()读取xml gps数据。我想输出不在线元素内的所有坐标点。下面包含在文件中,我想排除列出的坐标。

<place>
  <desc>home</desc>
  <line>
      <coordinate>123,123,123</coordinate>
      <coordinate>1223,1223,22123</coordinate>
  </line>
</place>

这是我想要输出和处理的有效坐标的示例(全部位于同一文件中):

<place>
   <desc>home</desc>
   <point>
      <coordinate>123,123,123</coordinate>
   </point>
</place>

不同之处在于,一个是线对象的一部分,另一个是一个点。我目前有这个代码,它抓住了一切。

            while (lxmlReader.Read())
            {

                    if (lxmlReader.NodeType == XmlNodeType.Element)
                    {
                        if (lxmlReader.Name == "coordinate")
                        {
                            rtxtOutput.Text += "\r\nElement Name: " + lxmlReader.Name.ToString();
                            rtxtOutput.Text += " Value: " + lxmlReader.ReadInnerXml().ToString();
                        }
                    }                   
            }

2 个答案:

答案 0 :(得分:4)

我不确定如何使用XmlReader(或者如果可能)使用XmlReader - 您是否考虑将XML加载到XmlDocument或XDocument对象中,这将允许您对其执行正确的查询。

然后你可以这样做:

XmlDocument doc = new XmlDocument();
doc.Load("path.xml");
foreach (XmlElement  pointCoord in doc.SelectNodes("/place/point/coordinate"))
{
    /Do something
}

您可以在线使用XPath找到大量基于父母等选择节点的示例。

答案 1 :(得分:1)

如果你有LINQ可用,我会做这样的事情:

IEnumerable<string> coords = XElement.Load("gps.xml")
    .Descendants("point")
    .Descendants("coordinate")
    .Select(c => c.Value);