博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
XML的C#解析
阅读量:6677 次
发布时间:2019-06-25

本文共 3428 字,大约阅读时间需要 11 分钟。

XML文件概述

XML全称Extensible Markup Language,可扩展标记语言,与超文本标记语言(HTML,HyperText Markup Language)同属于标准通用标记语言的子集。XML被设计用来传输和存储数据,使文档具有结构性;而HTML被设计用来显示数据。

XML的特点是:

– 与操作系统、编程语言的开发平台都无关;
– 可以实现不同系统之间的数据交互。

XML基本语法:
– 任何的起始标签都必须有一个结束标签,也可以使用简化写法,在大于符号之前紧跟一个斜线(/),例如,XML解析器会翻译成 ;
– 标签必须按合适的顺序进行嵌套,所以结束标签必须按镜像顺序匹配起始标签;
– 所有的特性都必须有值;
所有的特性都必须在值的周围加上单引号或双引号

在这里插入图片描述

XML声明

在这里插入图片描述

在这里插入图片描述

属性

在这里插入图片描述

所有的XML元素都必须有结束标签;
XML标签对大小写敏感;
必须正确地嵌套;
命名规则:
名称中可以包含字母、数字或者其他的字符;
不能以数字或者标点符号开始;
不能包含空格。

空元素可以简写在一对尖括号里面:

 

属性

语法如下,一个元素可以有多个属性:

<元素名 属性名="属性值" />
<元素名 属性名1="属性值1" 属性名2="属性值2" />eg.
Tom

**注释

XML文件中的注释采用 格式。

XML文件声明之前不能有注释;

注释不能嵌套。**

CDATA区

在编写XML文件时,有些内容可能不想让解析引擎解析执行,而是当作原始内容处理,遇到此种情况,可以把这些内容放在CDATA区里,对于CDATA区域内的内容,XML解析程序不会处理,而是直接原封不动的输出。
语法为:

C#读取XML文件

01创建xml文件

2
小伙砸
100
3
啦啦
200
4
哈哈
400

创建对应的类

public class skill    {        public int id { get; set;}        public string name { get; set; }        public string lange { get; set;}        public int damage { get; set;}        public override string ToString()        {            return $"{nameof(id)}: {id}, {nameof(name)}: {name}, {nameof(lange)}: {lange}, {nameof(damage)}: {damage}";        }    }

解析

class Program    {        static void Main(string[] args)        {            //xml.Load(path);//导入指定xml文件            //xml.Load(HttpContext.Current.Server.MapPath("~/file/bookstore.xml")); XmlNode root = xml.SelectSingleNode("/root");//指定一个节点            //XmlNodeList childlist = root.ChildNodes;//获取节点下所有直接子节点            //XmlNodeList nodelist = xml.SelectNodes("/Root/News");//获取同名同级节点集合string id=node.Attributes["id"].Value;//获取指定节点的指定属性值            //string content = node.InnerText;//获取指定节点中的文本            //root.HasChildNodes;//判断该节点下是否有子节点            skill skill=null;            XmlDocument xml =new XmlDocument();//初始化一个xml实例            xml.Load("SkillinfoList.txt");//载入文件            //xml.LoadXml(File.ReadAllText("SkillinfoList.txt"));//传递一个字符串            //得到根节点            //XmlNode root = xml.FirstChild;            //得到根节点的所有字节点            //XmlNodeList nodeList = root.ChildNodes;            //或者这个            XmlElement root = xml.DocumentElement;            XmlNodeList nodelist=root.ChildNodes;            //遍历输出.            foreach (XmlNode node in nodelist)            {                     int id = int.Parse(node.ChildNodes[0].InnerText);//InnerText节点包含的所有文本内容                string lang = node.ChildNodes[1].Attributes[0].InnerText;                string name = node.ChildNodes[1].InnerText;                int damage = int.Parse(node.ChildNodes[2].InnerText);                skill =new skill(){damage = damage,id = id,lange = lang,name = name,};                Console.WriteLine(skill.id + " " + skill.lange + " " + skill.name + " " + skill.damage);            }                    Console.ReadKey();        }    }

Document 对象的属性

XmlDocument类

1、DocumentElement属性返回根标签(不是根节点)。

2、XmlElement继承自XmlNode。可以通过XmlElement类对象获取属性的值,将XmlNode对象通过向下转型为XmlElement对象,在通过XMLElement对象获取属性值。GetAttribute(属性名)方法可以通过属性名访问某一个属性。

3、Load方法可以通过路径加载Xml文件,loadXml方法是通过string类型的文本加载Xml文件

4、XmlNodeList list=节点.ChildNodes返回所有子节点列表(注意该属性不返回孙节点)。

5、innerText属性返回该节点下包含的所有文本,包含子节点和孙节点中包含的文本。调用innerText 属性的节点下的所有文本都会放到一起,不会自动根据节点分割。可以通过键值对的形式访问对应子标签下的文本。例如父标签[“子标签”].innerText,访问子标签下的文本

转载地址:http://rcrxo.baihongyu.com/

你可能感兴趣的文章
性能下降曲线
查看>>
求一个数的二进制中1的个数
查看>>
古代教育观点纵览
查看>>
Linux 下搭建PHP环境(make方法)太麻烦了
查看>>
《三》kubectl命令行管理工具、YAML配置详解
查看>>
iozone测试文件系统性能
查看>>
Hadoop - HDFS的数据流剖析
查看>>
Win7下部署asp.net程序如果有RDLC报表需要以下配置
查看>>
Jhipster_cn中文翻译组
查看>>
Nagios简介与安装(1)
查看>>
centos 本地yum配置
查看>>
使用Vundle来管理vim的插件
查看>>
我们容易忽略的WebDriver 的一些方法
查看>>
一个算法,但是不知道名字,博客记录一下
查看>>
用AsyncTask来实现自己定义的观察者类(加载器)Loader(17)
查看>>
Windows借助脚本实现自动化加域
查看>>
构造函数私有化
查看>>
我的友情链接
查看>>
Linux Shell编程
查看>>
[Django](1093, "You can't specify target table。。错误
查看>>