对于一些数据不是很大的程序,或者只是一些配置文件,需要本地存储的,完全可以使用XML代替数据库,因为只是去操作单个文件会比操作数据库要简单很多,在程序中访问和操作XML一般使用DOM(文档对象模型)和流模式。DOM运行编辑和更新XML文档,可以随机访问文档中的数据,但有一个缺点,就是在加载XML的时候是会吧整个文档的加载进内存中。流模式很好的解决了这个问题,在对XML文件访问采用的是流的概念,任何时候在内存中只有当前接口,不足的地方是它是只读的,仅向前,不能再文档中去向后编辑增加。
XML(Extensible Markup Language)可扩展的标记语言,XML和HTML有很多地方都非常的类似,但HTML的语法不够严密,很松散,很多的格式没有强制的要求所以尤其在处理浏览器兼容的问题上需要费很大的心思啊,我特别有体会,很多不同的网站系统对浏览器就有要求,标准不统一,所以电脑上谷歌、火狐、360…..一大堆的浏览器就是为了适应不同的网站兼容的问题,XML有着严格的格式要求,比如要求元素必须是一对对显示的,XML还有一个很重要的特性就是通用性高,很多的程序包括Web和App底层数据交换都是转换成XML来进行数据交换的。
下面来看一个简单的XML文档:
1 <?xml version="1.0" encoding="utf-8" standalone=”yes”?> 2 3 <!—下面是学生名单--> 4 5 <学生名单> 6 7 <学生 id=”1”> 8 9 <学号>201701</学号> 10 11 <姓名>张三三</姓名> 12 13 <班级>0102</班级> 14 15 </学生> 16 17 <学生 id=”2”> 18 19 <学号>201702</学号> 20 21 <姓名>李四四</姓名> 22 23 <班级>0102</班级> 24 25 </学生> 26 27 <学生 id=”3”> 28 29 <学号>201703</学号> 30 31 <姓名>王五五</姓名> 32 33 <班级>0103</班级> 34 35 </学生> 36 37 </学生名单>
1.文档头部声明:
<?xml version="1.0" encoding="utf-8" ?>
?XML标记说明它是一个XML文档,version为版本号,encoding属性表明是编码格式为”utf-8”,standalone取”yes”时,表明该文件未引用其它外部文件。
2.注释:
<!--下面是学生名单-->
注释的格式和html类似:<!--“注释的内容”-->,使用注释时需要注意:1.注释不可以出现在XML声明之前.2.注释中不可以出现”--”字符,如:<!--下面是学生--名单> 3.注释不可以嵌套.
3.根元素:
<学生名单> XXX </学生名单>
每个文档必须有有一个根元素,没有根元素将会在解析的时候出现错误
4.元素(标记),是XML中用来定义数据的一个基本的单位,元素是由标记要定义的,同时标记分为非空标记和空标记:
(1)非空标记
<学号>201701</学号>
<姓名>张三三</姓名>
<班级>0102</班级>
非空即当标记中包含有内容,格式为:<标记>内容<标记>
(2)空标记
<学生 id=”1”></学生>
空标记中只有属性,两个标签中的内容是为空的。
XML位于System.Xml命名空间,以下为XML结构列表:
标 记 |
描 述 |
XmlDocument |
XML文档 |
XmlNode |
XML中单个的节点,如<学生名单> |
XmlAttribute |
XML元素中的属性 |
XmlText |
表示元素或属性的文本内容 |
XmlElement |
最小元素,如<姓名>张三三</姓名> |
XmlComment |
表示XML注释的内容 |
XmlDeclaration |
XML文档第一行的声明 |
XML文档的创建
最终效果:
<?xml version="1.0" encoding="UTF-8"?>
<学生名单>
<学生 id="1">
<姓名>张三三</姓名>
</学生>
</学生名单>
代码:
1 //创建一个XML文档对象 2 3 XmlDocument doc = new XmlDocument(); 4 5 //声明XML头部信息 6 7 XmlDeclaration dec = doc.CreateXmlDeclaration("1.0", "UTF-8", null); 8 9 //添加进doc对象子节点 10 11 doc.AppendChild(dec); 12 13 //创建根节点 14 15 XmlElement root = doc.CreateElement("学生名单"); 16 17 doc.AppendChild(root); 18 19 20 21 //再创建根节点下的子节点 22 23 XmlElement student = doc.CreateElement("学生"); 24 25 //设置子节点属性 26 27 student.SetAttribute("id", "1"); 28 29 //子节点下再创建标记 30 31 XmlElement studentName = doc.CreateElement("姓名"); 32 33 //<姓名>的内容 34 35 XmlText xmlText = doc.CreateTextNode("张三三"); 36 37 //将内容添加到<姓名>标记 38 39 studentName.AppendChild(xmlText); 40 41 //再将<姓名>标记添加到<学生>标记的子节点下 42 43 student.AppendChild(studentName); 44 45 //最后把<学生>标记添加到根节点<学生名单>子节点下 46 47 root.AppendChild(student); 48 49 //doc文档对象保存写入 50 51 doc.Save("Student.xml");
XML文档的读取
C#中XML读取有三种方式,XmlDocument,XmlTextReader,Linq to Xml,这几种方式中我个人习惯是用Linq,因为Linq去读取、筛选都会很方便,但是由于还没有写关于Linq的文章,这里我们使用XmlDocument的方式。
1 XmlDocument doc = new XmlDocument(); 2 3 //加载根目录下XML文件 4 5 doc.Load("XMLFile1.xml"); 6 7 //获取根节点 8 9 XmlElement root = doc.DocumentElement; 10 11 //获取<学生>子节点 12 13 XmlNodeList personNodes = root.GetElementsByTagName("学生"); 14 15 //使用foreach循环读出集合 16 17 foreach (XmlNode node in personNodes) 18 19 { 20 21 string id = ((XmlElement)node).GetAttribute("id"); 22 23 string name = ((XmlElement)node).GetElementsByTagName("姓名")[0].InnerText; 24 25 string number = ((XmlElement)node).GetElementsByTagName("学号")[0].InnerText; 26 27 string _class = ((XmlElement)node).GetElementsByTagName("班级")[0].InnerText; 28 29 Console.WriteLine("学生Id:{0},姓名:{1},学号:{2},班级:{3}", id, name, number, _class); 30 31 } 32 33 Console.ReadKey();
增加
1 string xmlPath = "XMLFile1.xml"; 2 3 XmlDocument doc = new XmlDocument(); 4 5 //加载根目录下XML文件 6 7 doc.Load(xmlPath); 8 9 //获取根节点 10 11 XmlElement root = doc.DocumentElement; 12 13 14 15 XmlElement student = doc.CreateElement("学生"); 16 17 student.SetAttribute("id", "4"); 18 19 //添加姓名标记 20 21 XmlElement studentName = doc.CreateElement("姓名"); 22 23 XmlText xmlText = doc.CreateTextNode("小明"); 24 25 studentName.AppendChild(xmlText); 26 27 //添加学号标记 28 29 XmlElement studentNumber = doc.CreateElement("学号"); 30 31 XmlText xmlText2 = doc.CreateTextNode("201704"); 32 33 studentNumber.AppendChild(xmlText2); 34 35 //添加班级标记 36 37 XmlElement studentClass = doc.CreateElement("班级"); 38 39 XmlText xmlText3 = doc.CreateTextNode("0102"); 40 41 studentClass.AppendChild(xmlText3); 42 43 44 45 //将上面创建的标记添加到<学生>标记 46 47 student.AppendChild(studentName); 48 49 student.AppendChild(studentNumber); 50 51 student.AppendChild(studentClass); 52 53 54 55 //将上面创建的标记添加到<学生名单>根标记 56 57 root.AppendChild(student); 58 59 60 61 //最后一步不要忘记了保存 62 63 doc.Save(xmlPath);
修改
1 string xmlPath = "XMLFile1.xml"; 2 3 XmlDocument doc = new XmlDocument(); 4 5 doc.Load(xmlPath); 6 7 XmlElement root = doc.DocumentElement; 8 9 //筛选出符合条件的标记 10 11 XmlElement selectEle = (XmlElement)root.SelectSingleNode("/学生名单/学生[@id='4']"); 12 13 //获取该标记下的子元素 14 15 XmlElement nameEle = (XmlElement)selectEle.GetElementsByTagName("姓名")[0]; 16 17 //修改<姓名>标记中的内容 18 19 nameEle.InnerText = "大明"; 20 21 //还是那句话不要忘记保存 22 23 doc.Save(xmlPath);
删除标记
删除和修改类似,也是筛选出符合条件的标记,然后移除
1 string xmlPath = "XMLFile1.xml"; 2 3 XmlDocument doc = new XmlDocument(); 4 5 doc.Load(xmlPath); 6 7 XmlElement root = doc.DocumentElement; 8 9 //筛选出符合条件的标记 10 11 XmlElement selectEle = (XmlElement)root.SelectSingleNode("/学生名单/学生[@id='4']"); 12 13 //删除指定子元素 14 15 root.RemoveChild(selectEle); 16 17 //还是那句话不要忘记保存 18 19 doc.Save(xmlPath);
以上就是XML基本的操作方法,当然如果使用Linq to Xml的话会更加的灵活,其它的几种操作方法有兴趣的同学也可以直接研究。