在C#中使用带有namespaced的xpathnavigator [英] Using xpathnavigator with namespaced in C#
问题描述
xml文件如下所示...
i希望得到两个数据'user_name'和'email'
在c#.......................中使用xpathnavigator但是不能......结果什么都没有......
-------------------------------------- -------------------------------------------------- -
xml file is like as below...
i want to get two data 'user_name' and 'email'
using xpathnavigator in c#.......................but can't... result is nothing...
------------------------------------------------------------------------------------------
<?xml version="1.0" encoding="UTF-8"?>
<MSG xmlns="http://tempuri.org/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<RD>
<xs:schema xmlns="" xmlns:msprop="urn:schemas-microsoft-com:xml-msprop" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata" xmlns:xs="http://www.w3.org/2001/XMLSchema" id="NewDataSet">
<xs:element msdata:UseCurrentLocale="true" msdata:IsDataSet="true" name="NewDataSet">
<xs:complexType>
<xs:choice maxOccurs="unbounded" minOccurs="0">
<xs:element name="Table" msprop:BaseTable.0="PATMAST_VIEW">
<xs:complexType>
<xs:sequence>
<xs:element name="USERNAME" minOccurs="0" type="xs:string" msprop:BaseColumn="USERNAME" msprop:OraDbType="126"/>
<xs:element name="EMAIL" minOccurs="0" type="xs:decimal" msprop:OraDbType="107"/>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:choice>
</xs:complexType>
</xs:element>
</xs:schema>
<diffgr:diffgram xmlns:msdata="urn:schemas-microsoft-com:xml-msdata" xmlns:diffgr="urn:schemas-microsoft-com:xml-diffgram-v1">
<NewDataSet xmlns="">
<Table diffgr:id="Table1" msdata:rowOrder="0">
<USERNAME>Jim</USERNAME>
<EMAIL>1</EMAIL>
</Table>
</NewDataSet>
</diffgr:diffgram>
</RD>
</MSG >
我尝试过:
...读取xml ...
XPathNavigator xpN = xDoc.CreateNavigator();
XPathExpression expression = xpN.Compile( 'MSG / RD / diffgr:diffgram / NewDataSet / Table / USERNAME');
XmlNamespaceManager manager = new XmlNamespaceManager(xpN.NameTable);
manager.AddNamespace(diffgr ,urn:schemas-microsoft-com:xml-diffgram-v1);
expression.SetContext(manager);
XPathNodeIterator iter = xpN.Select(expression );
if(iter.Count< = 0)继续;
......
What I have tried:
...read xml...
XPathNavigator xpN = xDoc.CreateNavigator();
XPathExpression expression = xpN.Compile('MSG/RD/diffgr:diffgram/NewDataSet/Table/USERNAME');
XmlNamespaceManager manager = new XmlNamespaceManager(xpN.NameTable);
manager.AddNamespace("diffgr", "urn:schemas-microsoft-com:xml-diffgram-v1");
expression.SetContext(manager);
XPathNodeIterator iter = xpN.Select(expression);
if (iter.Count <= 0) continue;
......
推荐答案
替代方法。
使用DataSet会自动为您提供表结构。
Alternative way to do it.
Using a DataSet will automatically give you the table structure.
XDocument xDoc = XDocument.Load('your file name');
XElement xeMsg = xDoc.Element(XName.Get("MSG", "http://tempuri.org/"));
XElement xeRd = xeMsg.Element(XName.Get("RD", "http://tempuri.org/"));
DataSet ds = new DataSet();
ds.ReadXml(xeRd.CreateReader());
if (ds.Tables["Table"].Rows.Count == 1)
{
DataRow dr = ds.Tables["Table"].Rows[0];
string userName = dr["USERNAME"].ToString();
string email = dr["EMAIL"].ToString();
}
这篇关于在C#中使用带有namespaced的xpathnavigator的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!