C#读取XML的CDATA节点内容实例详解

首先看实例代码:

昨天读取了以下XML, 之前没有读取过类似的格式,用一种比较笨的方法读取的,记录下
<?xml version="1.0"?>
<response>
<srvver>1.0</srvver>
<srvcode>000</srvcode>
<payload>
<param type="XML" key="data">
<![CDATA[
<Response>
 <Execution>
  <Status code="0" sql_code="0" description="执行成功!"/>
 </Execution>
 <ResponseContent>
  <Parameter/>
  <Document>
   <RecordSet id="1">
    <Master name="M" node_id="1">
     <Record>
      <Field name="MTRL_ID" value="51722500H031"/>
      <Field name="IS_MAIN" value="Y"/>
      <Field name="MAIN_ID" value="51722500H031"/>
      <Field name="DOSAGE" value="1.0"/>
      <Field name="NN_QTY" value="1000.0"/>
      <Field name="TN_QTY" value="1000.0"/>
      <Field name="SEQ" value="70.0"/>
      <Field name="POINT_STR" value=""/>
     </Record>
    </Master>
   </RecordSet>
   <RecordSet id="2">
    <Master name="M" node_id="2">
     <Record>
      <Field name="MTRL_ID" value="51820590H001"/>
      <Field name="IS_MAIN" value="N"/>
      <Field name="MAIN_ID" value="51820590H001"/>
      <Field name="DOSAGE" value="1.0"/>
      <Field name="NN_QTY" value="1000.0"/>
      <Field name="TN_QTY" value="500.0"/>
      <Field name="SEQ" value="30.0"/>
      <Field name="POINT_STR" value=""/>
     </Record>
    </Master>
   </RecordSet>
   <RecordSet id="3">
    <Master name="M" node_id="3">
     <Record>
      <Field name="MTRL_ID" value="51820710H002"/>
      <Field name="IS_MAIN" value="N"/>
      <Field name="MAIN_ID" value="51820510H002"/>
      <Field name="DOSAGE" value="0.0"/>
      <Field name="NN_QTY" value="0.0"/>
      <Field name="TN_QTY" value="1000.0"/>
      <Field name="SEQ" value="20.0"/>
      <Field name="POINT_STR" value=""/>
     </Record>
    </Master>
   </RecordSet>
  </Document>
 </ResponseContent>
</Response>
]]>
</param>
</payload>
</response>

以下是读取xml节点的过程

我的目的是想要读取CDATA里面的 <RecordSet></RecordSet> 包裹的数据

1.我先建立了一个类

public class ReadXml
  {
    public string RecordSet;
    public string MTRL_ID;
    public string IS_MAIN;
    public string MAIN_ID;
    public string DOSAGE;
    public string NN_QTY;
    public string TN_QTY;
    public string SEQ;
    public string POINT_STR;
  }

2. 接着我把CDATA里面的内容提出来

XmlDocument doc = new XmlDocument();
      doc.LoadXml(strFile); var cdata = (XmlCDataSection)doc.SelectSingleNode("/response/payload/param/text()");

3. 然后用XElement的Linq方法找到 RecordSet 节点集合, 循环节点集合,赋值,以下是实现代码:

XElement xe = XElement.Parse(cdata.InnerText);
 IEnumerable<XElement> elements = from ele in xe.Elements("ResponseContent").Elements("Document").Elements("RecordSet") select ele;
      List<ReadXml> xmlNodeList = new List<ReadXml>();
      foreach (var ele in elements)
      {
        ReadXml xmlNode= new ReadXml();
        model.RecordSet = ele.Attribute("id").Value;

        var subeles = ele.Elements("Master").Elements("Record").Elements("Field");
        foreach (var item in subeles)
        {
          if (item.Attribute("name").Value == "MTRL_ID")
          {
            xmlNode.MTRL_ID = item.Attribute("name").NextAttribute.Value;
          }
          if (item.Attribute("name").Value == "IS_MAIN")
          {
            xmlNode.IS_MAIN = item.Attribute("name").NextAttribute.Value;
          }
          if (item.Attribute("name").Value == "MAIN_ID")
          {
            xmlNode.MAIN_ID = item.Attribute("name").NextAttribute.Value;
          }
          if (item.Attribute("name").Value == "DOSAGE")
          {
            xmlNode.DOSAGE = item.Attribute("name").NextAttribute.Value;
          }
          if (item.Attribute("name").Value == "NN_QTY")
          {
            xmlNode.NN_QTY = item.Attribute("name").NextAttribute.Value;
          }
          if (item.Attribute("name").Value == "TN_QTY")
          {
            xmlNode.TN_QTY = item.Attribute("name").NextAttribute.Value;
          }
          if (item.Attribute("name").Value == "SEQ")
          {
            xmlNode.SEQ = item.Attribute("name").NextAttribute.Value;
          }
          if (item.Attribute("name").Value == "POINT_STR")
          {
            xmlNode.POINT_STR=item.Attribute("name").NextAttribute.Value;
          }
        }
        xmlNodeList.Add(xmlNode);
      }

以上就是本次介绍的全部知识点内容,感谢大家的阅读和对我们的支持。

(0)

相关推荐

  • C#读取XML的CDATA节点内容实例详解

    首先看实例代码: 昨天读取了以下XML, 之前没有读取过类似的格式,用一种比较笨的方法读取的,记录下 <?xml version="1.0"?> <response> <srvver>1.0</srvver> <srvcode>000</srvcode> <payload> <param type="XML" key="data"> <![CDA

  • 对python修改xml文件的节点值方法详解

    这是我的xml文件结构 <?xml version='1.0' encoding='utf-8'?> <annotation> <folder>JPEGImages</folder> <filename>train_2018-05-08_1000.jpg</filename> <path>D:\all_data\2018-05-08\JPEGImages\train_2018-05-08_1000.jpg</path

  • Python中读取文件名中的数字的实例详解

    我们在使用计算机时,我们创建一个个文件夹,可以节省桌面空间,做好整理归纳.python中,每个文件中有着不同的内容,我们要想使用文件,就要读取文件.本文向大家介绍Python读取文件名中的数字的方法:1.使用正则表达式:2.获取匹配的字符串:3.需要整数,可以使用int:4.生成数字. 第一步:可以使用正则表达式 regex = re.compile(r'\d+') 第二步:然后获取匹配的字符串 regex.findall(filename) 这将返回包含数字的字符串列表. 第三步:如果您实际需

  • python 读取excel文件生成sql文件实例详解

    python 读取excel文件生成sql文件实例详解 学了python这么久,总算是在工作中用到一次.这次是为了从excel文件中读取数据然后写入到数据库中.这个逻辑用java来写的话就太重了,所以这次考虑通过python脚本来实现. 在此之前需要给python添加一个xlrd模块,这个模块是专门用来操作excel文件的. 在mac中可以通过easy_install xlrd命令实现自动安装模块 import xdrlib ,sys import xlrd def open_excel(fil

  • python下读取公私钥做加解密实例详解

    python下读取公私钥做加解密实例详解 在RSA有一种应用模式是公钥加密,私钥解密(另一种是私钥签名,公钥验签).下面是Python下的应用举例. 假设我有一个公钥文件,rsa_pub.pem, 我要读取这个公钥并用它来加密. from M2Crypto import RSA,BIO fp = file('rsa_pub.pem','rb'); pub_key_str = fp.read(); fp.close(); mb = BIO.MemoryBuffer(pub_key_str); pu

  • Python3使用腾讯云文字识别(腾讯OCR)提取图片中的文字内容实例详解

    百度OCR体验地址: https://ai.baidu.com/tech/imagerecognition/general 腾讯OCR体验地址: https://cloud.tencent.com/act/event/ocrdemo 测试结果是:腾讯的效果要比百度的好 腾讯云目前额度是: 每个接口 1,000次/月免费,有6个文字识别的接口,一共是6,000次/月 百度接口调用之前写过文章 python实现百度OCR图片识别过程解析 使用步骤 1.注册账号: https://cloud.tenc

  • javascript解析ajax返回的xml和json格式数据实例详解

    本文实例讲述了javascript解析ajax返回的xml和json格式数据.分享给大家供大家参考,具体如下: 写个例子,以备后用 一.JavaScript 解析返回的xml格式的数据: 1.javascript版本的ajax发送请求 (1).创建XMLHttpRequest对象,这个对象就是ajax请求的核心,是ajax请求和响应的信息载体,单是不同浏览器创建方式不同 (2).请求路径 (3).使用open方法绑定发送请求 (4).使用send() 方法发送请求 (5).获取服务器返回的字符串

  • python 根据正则表达式提取指定的内容实例详解

    python 根据正则表达式提取指定的内容 正则表达式是极其强大的,利用正则表达式来提取想要的内容是很方便的事. 下面演示了在python里,通过正则表达式来提取符合要求的内容. 实例代码: import re # 正则表达式是极其强大的,利用正则表达式来提取想要的内容是很方便的事. # 下面演示了在python里,通过正则表达式来提取符合要求的内容.有几个要注意 # 的地方就是: # [1] 要用()将需要的内容包含起来 # [2] 编号为0的group是整个符合正则表达式的内容,编号为1的是

  • Java 是如何读取和写入浏览器Cookies的实例详解

    首先我们认识下什么是cookies: cookie实际上是一个存在你硬盘里的数据,但是这些数据很特殊,只能由web应用提交给浏览器帮助存储,并且我们还能读取浏览器的cookie web应用一般只在cookie中存储一些用户信息等少量且暂时的数据,数据量大则不适合存储在cookies 一般浏览器对于每个web应用会分别给予他们40个cookie用来存储数据,并且每个cookie的大小不超过4K(听说部分浏览器的cookie能存很大的数据,不过我们一般不会存这么大的数据,因为数据提取的效率不高,影响

  • C# XML与Json之间相互转换实例详解

    对于这转换其实很简单,其中最重要的就是先要引用类库.可以到官网进行下载引用http://json.codeplex.com. XML转换为Json字符串 复制代码 代码如下: string xml = @"<?xml version=""1.0"" standalone=""no""?>                             <root>                   

随机推荐