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

 更新时间:2019年09月03日 15:52:20   作者:需要充电  
在本篇文章里小编给大家整理了关于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);
      }

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

相关文章

  • C#冒泡法排序算法实例分析

    C#冒泡法排序算法实例分析

    这篇文章主要介绍了C#冒泡法排序算法,结合两个常用实例分析了C#冒泡排序算法的相关实现技巧,需要的朋友可以参考下
    2015-07-07
  • C#难点逐个击破(9):类型转换

    C#难点逐个击破(9):类型转换

    类型之间的转换可以分为隐式转换与显式转换,如int类型可直接转换为long类型。
    2010-02-02
  • C# 线性插值的实现示例

    C# 线性插值的实现示例

    线性插值是针对一维数据的插值方法,本文主要介绍了C# 线性插值的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2024-03-03
  • C#中 Json 序列化去掉null值的方法

    C#中 Json 序列化去掉null值的方法

    要将一个对象序列化,可是如果对象的属性为null的时候,我们想将属性为null的都去掉,怎么处理呢?其实方法很简单的,下面就跟随脚本之家小编一起学习C#中 Json 序列化去掉null值的方法吧
    2017-09-09
  • C#实现远程关闭和重启计算机的示例代码

    C#实现远程关闭和重启计算机的示例代码

    这篇文章主要为大家详细介绍了如何利用C#实现远程关闭和重启计算机的功能,文中的示例代码讲解详细,对我们学习C#有一定的帮助,感兴趣的小伙伴可以跟随小编一起了解一下
    2022-12-12
  • c# 实现雪花分形的示例

    c# 实现雪花分形的示例

    这篇文章主要介绍了c# 实现雪花分形的示例,帮助大家更好的利用c#绘制图像,感兴趣的朋友可以了解下
    2020-10-10
  • C# 单元测试全解析

    C# 单元测试全解析

    这篇文章主要介绍了C# 单元测试的相关资料,帮助大家更好的理解和学习使用c#,感兴趣的朋友可以了解下
    2021-04-04
  • C#的通用DbHelper类(支持数据连接池)示例详解

    C#的通用DbHelper类(支持数据连接池)示例详解

    这篇文章主要介绍了C#的通用DbHelper类支持数据连接池,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • WPF+Canvas实现平滑笔迹的示例代码

    WPF+Canvas实现平滑笔迹的示例代码

    这篇文章主要介绍了如何利用WPF+Canvas实现平滑笔迹效果,文中的示例代码讲解详细,对我们学习或工作有一定帮助,需要的可以参考一下
    2022-09-09
  • C#如何将DataTable导出到Excel解决方案

    C#如何将DataTable导出到Excel解决方案

    由于公司项目中需要将系统内用户操作的所有日志进行转存备份,考虑到以后可能还需要还原,所以最后决定将日志数据备份到Excel中
    2012-11-11

最新评论