正在解析 xml 响应 - Select 基于另一个节点值的特定节点

Parsing xml response - Select specific node based on value of another node

我是 xml 的新手,所以我不确定我的问题措辞是否正确,但我会尽力解释。

基本上,我正在尝试解析 C# 中的 xml 响应,如下所示:

<Premium>
        <TotalPremiumAmount>87</TotalPremiumAmount>
        <StandardPremium>87</StandardPremium>
        <OptionalPremium>0</OptionalPremium>
        <StandardTax>0</StandardTax>
        <OptionalTax>0</OptionalTax>
        <ExtendedTax>0</ExtendedTax>
        <ExtendedPremium>0</ExtendedPremium>
        <PromotionalPremium>0</PromotionalPremium>
        <FeesPremium>0</FeesPremium>
        <FeesTax>0</FeesTax>
        <StandardFeesPremium>0</StandardFeesPremium>
        <OptionalFeesPremium>0</OptionalFeesPremium>
        <Tax>0</Tax>
        <StandardPremiumDistribution>
            <Travelers>
                <Traveler>
                    <TravelerPremium>42</TravelerPremium>
                    <TravelerTax>0</TravelerTax>
                </Traveler>
                <Traveler>
                    <TravelerPremium>45</TravelerPremium>
                    <TravelerTax>0</TravelerTax>
                </Traveler>
            </Travelers>
        </StandardPremiumDistribution>
        <PackagePremiumDistribution>
            <Packages>
                <Package>
                    <PackageID>20265</PackageID>
                    <PackageName />
                    <PackageTypeID>12</PackageTypeID>
                    <Premium>87</Premium>
                    <Fees>0</Fees>
                    <Tax>0</Tax>
                    <Travelers>
                        <Traveler>
                            <TravelerID>0</TravelerID>
                            <Premium>42</Premium>
                            <Tax>0</Tax>
                        </Traveler>
                        <Traveler>
                            <TravelerID>1</TravelerID>
                            <Premium>45</Premium>
                            <Tax>0</Tax>
                        </Traveler>
                    </Travelers>
                </Package>
            </Packages>
        </PackagePremiumDistribution>
    </Premium>

我想获得(旅行者)保费的价值。在只有一个旅行者的情况下,我一直在使用 XMLDocument 和“SelectSingleNode”函数。例如,我可以这样做:

XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(xmlResponse);
var premium = xmlDoc.SelectSingleNode("//TravelerPremium").InnerText;

但是当多个旅行者根据一个计划返回时,这将不起作用。例如,当 TravelerID = 0 时我需要保费。我该怎么做?

谢谢。

假设您的 xml 看起来像那样,请尝试这样的操作:

XmlDocument doc = new XmlDocument();
xmlDoc.Load(xmlResponse);

if (doc.HasChildNodes)
                {
                    foreach (XmlNode node in doc.DocumentElement.ChildNodes)
                       if (node.Name == "StandardPremiumDistribution")
                        {
XmlNodeList xnList = node.SelectNodes("//Travelers");
double travelerPremium= xnList.Item(z).FirstChild.InnerText);

}}

基于此,我认为你会去做。

假设您有一个名为 XMLFile1.xml 的文件,其中包含您发布的 XML 您可以使用以下代码遍历所有 TravelerPremium:

    XmlDocument xmlDoc = new XmlDocument();
    xmlDoc.Load("XMLFile1.xml");
    XmlNodeList premiums = xmlDoc.SelectNodes("//TravelerPremium");
    foreach(XmlNode node in premiums)
    {
        MessageBox.Show(node.FirstChild.InnerText);
    }

您也可以使用类似的代码访问其他元素。

使用 XmlDocument:

XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(xmlResponse);
var premium = xmlDoc.SelectSingleNode("//Premium[../TravelerID = '0']")

如果多个节点可以在这种情况下匹配,您也可以遍历节点,如下所示:

foreach(var premium in xmldoc.SelectNodes("//Premium[../TravelerID = '0']")
{
   // do work on each premium node where TravelerID = 0
}

我鼓励您考虑使用 LINQ to XML - 它通常更易于使用,并且在大多数情况下性能更高。您甚至还可以使用 XPath 表达式,但以下内容会起作用:

XDocument xdoc = XDocument.Load(xmlResponse);
var premium = (string)xdoc.Descendants("Traveler").Where(x => (string)x.Element("TravelerID") == "0").Element("Premium");