服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C# - C#读取XML的CDATA节点内容实例详解

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

2022-08-05 10:56需要充电 C#

在本篇文章里小编给大家整理了关于C# 读取XML的CDATA节点内容的相关知识点内容,有需要的朋友们参考学习下。

首先看实例代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
昨天读取了以下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.我先建立了一个类

?
1
2
3
4
5
6
7
8
9
10
11
12
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里面的内容提出来

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

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
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);
      }

 

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

原文链接:https://www.cnblogs.com/twostare/p/11452361.html

延伸 · 阅读

精彩推荐
  • C#C# 使用SharpZipLib生成压缩包的实例代码

    C# 使用SharpZipLib生成压缩包的实例代码

    SharpZipLib是一个C#的类库,主要用来解压缩Zip,GZip,BZip2,Tar等格式,是以托管程序集的方式实现,可以方便的应用于其他的项目之中。本文通过一个实例代码给...

    Alan.hsiang6992022-03-01
  • C#使用C#给PDF文档添加注释的实现代码

    使用C#给PDF文档添加注释的实现代码

    本文将实例讲述C#中如何使用免费组件给PDF文档添加文本注释,包括自由文本注释。自由文本注释能允许我们自定义它的风格和外观,非常具有实用价值...

    C#教程网8582021-12-21
  • C#C#实现DataSet内数据转化为Excel和Word文件的通用类完整实例

    C#实现DataSet内数据转化为Excel和Word文件的通用类完整实例

    这篇文章主要介绍了C#实现DataSet内数据转化为Excel和Word文件的通用类,涉及C#中DataSet控件的使用及Excel和Word文件的相关操作技巧,需要的朋友可以参考下...

    雨竹10732021-11-26
  • C#深入解析C#编程中泛型委托的使用

    深入解析C#编程中泛型委托的使用

    这篇文章主要介绍了C#编程中泛型委托的使用,引用泛型委托的代码可以指定类型参数以创建已关闭的构造类型,需要的朋友可以参考下...

    Fastyou4242021-11-12
  • C#C#实现将一个字符串进行翻转显示的6种方法

    C#实现将一个字符串进行翻转显示的6种方法

    下面小编就为大家分享一篇C#实现将一个字符串进行翻转显示的6种方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    杨明波(Leo Yang)6512022-02-16
  • C#C#实现自定义Dictionary类实例

    C#实现自定义Dictionary类实例

    这篇文章主要介绍了C#实现自定义Dictionary类,较为详细的分析了Dictionary类的功能、定义及用法,具有一定参考借鉴价值,需要的朋友可以参考下...

    北风其凉11952021-10-18
  • C#WinForm单例窗体用法实例

    WinForm单例窗体用法实例

    这篇文章主要介绍了WinForm单例窗体,结合实例形式分析了窗体的单例模式定义、实现与使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下...

    HTL6802021-12-01
  • C#C# Oracle批量插入数据进度条的实现代码

    C# Oracle批量插入数据进度条的实现代码

    这篇文章主要介绍了C# Oracle批量插入数据进度条的实现代码,需要的朋友可以参考下...

    heyyw9032022-02-22