我有一个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>
标记内的值。我怎么能这样做?
答案 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,并确保选中后所选节点不为空。