C# - 从XML文档中的特定标记获取值

时间:2016-08-22 11:19:49

标签: c# .net xml

我有一个xml文档,如下所示:

<?xml version="1.0" encoding="UTF-8"?>
<cbn:PaidOrderNotification xmlns:cbn="http://xml.test.com/3.12.0.0/test.xsd">
    <cbn:NotificationDate>2016-08-01T07:28:46.679414Z</cbn:NotificationDate>
    <cbn:Purchase cbt:Id="95368158" xmlns:cbt="http://xml.test.com/3.12.0.0/testTypes.xsd">
        <cbt:Status>Test Order</cbt:Status>
        <cbt:Items>
            <cbt:Item cbt:RunningNo="1">
                <cbt:ProductId>178732</cbt:ProductId>
                <cbt:Payment cbt:SubscriptionId="S18767146">
                    <cbt:CancelUrl>https://store.test.com/</cbt:CancelUrl>
                    <cbt:ChangeUrl>https://test.com/</cbt:ChangeUrl>
                </cbt:Payment>
            </cbt:Item>
        </cbt:Items>
        <cbt:ExtraParameters />
    </cbn:Purchase>
</cbn:PaidOrderNotification>

使用C#,我希望获得<cbt:CancelUrl>标记内的值。我怎么能这样做?

3 个答案:

答案 0 :(得分:6)

首先阅读xml文档,如:

var doc = new XmlDocument();
            doc.LoadXml(_xml);

然后你可以写:

 string CancelUrl = doc.GetElementsByTagName("cbt:CancelUrl")[0].InnerText;
 string ChangeUrl = doc.GetElementsByTagName("cbt:ChangeUrl")[0].InnerText;

答案 1 :(得分:2)

选择它的方法,如果使用Linq to Xml,则定义XNamespace对象如下:

XNamespace cbt = "http://xml.test.com/3.12.0.0/testTypes.xsd";

var result = XDocument.Load("data.xml").Root
         .Descendants(cbt + "CancelUrl")
         .FirstOrDefault()?.Value;

//result - https://store.test.com/

答案 2 :(得分:1)

XmlDocument XmlNamespaceManager类将支持获取数据所需的XPath表达式。

//Load the document
XmlDocument order = new XmlDocument();
order.Load("filepath.xml");

实例化命名空间管理器:

XmlNamespaceManager xmlns = new XmlNamespaceManager(order.NameTable);
xmlns.AddNamespace("cbt", "http://xml.test.com/3.12.0.0/testTypes.xsd");

现在,您可以使用命名空间管理器来选择所需的信息。 此XPath表达式("//cbt:CancelUrl")选择整个文档中的任何CancelUrl节点,并且可以使用更合格的路径使其更具体。

string xpath = "//cbt:CancelUrl"
XmlNode cancelUrl = Order.SelectSingleNode(xpath, xmlns);
string value = cancelUrl.InnerText;

您可能需要更仔细地指定XPath,并确保选中后所选节点不为空。