在C#中使用带有namespaced的xpathnavigator [英] Using xpathnavigator with namespaced in C#

查看:99
本文介绍了在C#中使用带有namespaced的xpathnavigator的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

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屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆