linq 用C#查找具有一定值的XML-Node

guz6ccqo  于 2023-05-20  发布在  C#
关注(0)|答案(1)|浏览(96)

给定一个具有如下结构的XML:

<?xml version="1.0" encoding="UTF-8"?>
<BMECAT version="2005" xmlns="http://www.bmecat.org/bmecat/2005+onto" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.eclass.eu/static/eClassXML/2.0/bmecat/bmecat_2005onto.xsd">
    <T_NEW_CATALOG>
        <PRODUCT mode="new">            
            <PRODUCT_FEATURES>
                <FEATURE>
                    <FTEMPLATE>
                        <FT_ID>0173-1#02-BAC137#006</FT_ID>
                        <FT_NAME>Breite</FT_NAME>
                    </FTEMPLATE>
                    <FVALUE>10</FVALUE>
                    <FUNIT>0173-1#05-AAA480#003</FUNIT>
                    <FID>375397708</FID>
                    <FPARENT_ID>-1</FPARENT_ID>
                </FEATURE>
                <FEATURE>
                    <FTEMPLATE>
                        <FT_ID>0173-1#02-BAC476#007</FT_ID>
                        <FT_NAME>Höhe</FT_NAME>
                    </FTEMPLATE>
                    <FVALUE>51.5</FVALUE>
                    <FUNIT>0173-1#05-AAA480#003</FUNIT>
                    <FID>375397709</FID>
                    <FPARENT_ID>-1</FPARENT_ID>
                </FEATURE>
                <FEATURE>
                    <FTEMPLATE>
                        <FT_ID>0173-1#02-BAA351#014</FT_ID>
                        <FT_NAME>Farbe</FT_NAME>
                    </FTEMPLATE>
                    <VALUE_IDREF>0173-1#07-AAA875#004</VALUE_IDREF>
                    <FID>375397710</FID>
                    <FPARENT_ID>-1</FPARENT_ID>
                </FEATURE>
                <FEATURE>
                    <FTEMPLATE>
                        <FT_ID>0173-1#02-BAA018#007</FT_ID>
                        <FT_NAME>Länge</FT_NAME>
                    </FTEMPLATE>
                    <FVALUE>55.5</FVALUE>
                    <FUNIT>0173-1#05-AAA480#003</FUNIT>
                    <FID>375397711</FID>
                    <FPARENT_ID>-1</FPARENT_ID>
                </FEATURE>
            </PRODUCT_FEATURES>
        </PRODUCT>
    </T_NEW_CATALOG>
</BMECAT>

在第一步中,我想选择FT_NAME为“Breite”的所有FEATURE元素。在此之后,我想得到该特征的F值。
我试着用

XElement root = XElement.Load("File.xml");
IEnumerable<XElement> elements =
    from el in root.Elements("FEATURE")
    where (string)el.Element("FT_NAME") == "Breite"
    select el;

但没有任何结果

nhaq1z21

nhaq1z211#

这里有几个问题:

  • Elements只返回 * 直接子元素 * -不是所有的后代。您的根文档不包含任何FEATURE元素作为直接子元素,FEATURE元素也不包含FT_NAME元素作为直接子元素。为此,可以使用Descendants而不是Elements
  • 您的元素都在http://www.bmecat.org/bmecat/2005+onto名称空间中,但您没有在任何地方指定它。

下面的代码示例解决了这两个问题:

XNamespace ns = "http://www.bmecat.org/bmecat/2005+onto";
// Used XDocument instead of XElement as really that's
// what your file contains
var doc = XDocument.Load("Test.xml");

var elements =
    from el in doc.Descendants(ns + "FEATURE")
    where (string) el.Descendants(ns + "FT_NAME").SingleOrDefault() == "Breite"
    select el;

foreach (var element in elements)
{
    Console.WriteLine(element.Element(ns + "FTEMPLATE").Element(ns + "FT_ID").Value);
}

相关问题