XML文档操作集锦(C#篇)
在JSON没流行起来的时候xml一直作为程序存储配置信息的主流介质;特别是小型数据表方面还是不错的选择,所以经常涉及到的操作无非也就是增删改查,这篇博客主要是对这些对比较常用的操作做了个简单的总结
文件加载
SelectNodes()、SelectSingleNode()节点获取大法
创建XML文档及设置元素值
XmlReader与XmlWriter
DataSet与XML数据
Linq to XML
XML序列化与反序列化
文件加载
- 通过路径加载XML
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(fileName);//文件路径或者URL地址
Console.WriteLine(xmlDoc.InnerXml);
Console.WriteLine("==============有逼格的分割线================");
xmlDoc.Load("http://feed.cnblogs.com/blog/picked/rss");//博客园精华帖RSS
Console.WriteLine(xmlDoc.InnerXml);
- 通过文件流加载
using (FileStream stream = new FileStream(fileName, FileMode.Open, FileAccess.Read))
{
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(stream);
Console.WriteLine(xmlDoc.InnerXml);
}
Load()方法还重载了一些方法,并且还有别的方式可以加载XML文档,比如LoadXml()直接加载一段XML串
SelectNodes()、SelectSingleNode()节点获取大法
<?xml version="1.0" encoding="utf-8" ?>
<Names>
<Name>
<FirstName>John</FirstName>
<LastName>Smith</LastName>
</Name>
<Name>
<FirstName>James</FirstName>
<LastName>White</LastName>
</Name>
</Names>
XML文件
- 通过XPath表达式的SelectNodes(string xpath)方法获取节点列表;SelectSingleNode(string xpath)获取第一个匹配的节点
XmlNodeList xmlNodes = xmlDoc.SelectNodes("/Names/Name");//第一个斜杠必须是根节点
foreach (XmlNode item in xmlNodes)
{
Console.WriteLine(item.InnerXml);
}
Console.WriteLine("==================================");
XmlNode xmlNode = xmlDoc.SelectSingleNode("/Names/Name");
Console.WriteLine(xmlNode.InnerXml);
Console.WriteLine(xmlNode["LastName"].InnerText);//获取子节点
- 设置节点特性值查找节点
<Root> <Item Id="1" Grade="1">张三</Item> <Item Id="2" Grade="1">李四</Item> <Item Id="3" Grade="2">王五</Item> <Item Id="4" Grade="3">赵六</Item> </Root>
XmlNodeList xmlNodes = xmlDoc.SelectNodes("/Root/Item[@Grade='1']");//XPath表达式获取设置要获取节点的特性值信息
foreach (XmlNode item in xmlNodes)
{
Console.WriteLine(item.InnerText);
}
- 获取第N个节点
XmlNode xmlNode = xmlDoc.SelectSingleNode("/Root/Item[position()=3]");//获取第N个节点(根据XML节点的顺序)
Console.WriteLine(xmlNode.InnerText);
Console.WriteLine("==============================");
XmlNodeList xmlNodes = xmlDoc.SelectNodes("/Root/Item[position()<=3]");//获取从第一个到第N个的节点(根据XML节点的顺序
foreach (XmlNode item in xmlNodes)
{
Console.WriteLine(item.InnerText);
}
Console.WriteLine("==============================");
xmlNodes = xmlDoc.SelectNodes("/Root/Item[position() > 2]");//获取大于第N个的节点(根据XML节点的顺序)
foreach (XmlNode item in xmlNodes)
{
Console.WriteLine(item.InnerText);
}
创建XML文档及设置元素值
XmlDocument xmlDoc = new XmlDocument();
XmlNode rootNode = xmlDoc.CreateElement("Root");//创建一个节点
xmlDoc.AppendChild(rootNode);
Console.WriteLine(xmlDoc.InnerXml);
Console.WriteLine("==============有逼格的分割线================");
XmlNode node = xmlDoc.CreateElement("Item");
XmlAttribute attribute = xmlDoc.CreateAttribute("Id");//创建节点特性
attribute.Value = ";//设置特性值
node.Attributes.Append(attribute);
node.InnerText = "张三";
rootNode.AppendChild(node);
Console.WriteLine(xmlDoc.InnerXml);
Console.WriteLine("==============有逼格的分割线================");
node = xmlDoc.CreateElement("Item");
attribute = xmlDoc.CreateAttribute("Id");
attribute.Value = ";
node.Attributes.Append(attribute);
node.InnerText = "李四";
rootNode.AppendChild(node);
Console.WriteLine(xmlDoc.InnerXml); xmlDoc.Save(fileName);//保存到文件
XmlReader与XmlWriter
XmlReader操作XML比XmlDocument更快、内存消耗更少(可以写一个测试验证一下);但是它需要去手动判断元素的类型,操作起来比XmlDocument稍微蛋疼一些
using (XmlWriter xmlWriter = XmlWriter.Create(fileName))
{
xmlWriter.WriteStartDocument();//开始写入xml文档
xmlWriter.WriteStartElement("users");
xmlWriter.WriteStartElement("user");
xmlWriter.WriteAttributeString(");
xmlWriter.WriteString("张三");
xmlWriter.WriteEndElement();
xmlWriter.WriteStartElement("user");
xmlWriter.WriteAttributeString(");
xmlWriter.WriteString("李四");
xmlWriter.WriteEndDocument();//结束写入xml文档
}
using (XmlReader xmlReader = XmlReader.Create(fileName))
{
while (xmlReader.Read())
{
if (xmlReader.NodeType == XmlNodeType.Element)//元素的类型
{
Console.WriteLine(xmlReader.Name);//元素名称
if (xmlReader.HasAttributes)
{
Console.WriteLine(xmlReader.GetAttribute("Id"));//元素名称
}
Console.WriteLine(xmlReader.ReadOuterXml());//获取节点的所有子内容
}
}
}
DataSet与XML数据
通过XmlReader将数据读入到DataSet数据集中
using (XmlReader xmlReader = XmlReader.Create(fileName, new XmlReaderSettings()))
{
DataSet ds = new DataSet();
ds.ReadXml(xmlReader);
DataTable dt = ds.Tables[];
; i < dt.Rows.Count - ; i++)
{
object[] items = dt.Rows[i].ItemArray;
Console.WriteLine(string.Join(" ", items));
}
}
将数据表保存到XML文件也是比较常用的
DataSet ds = new DataSet();
DataTable dt = new DataTable();
dt.Columns.Add(new DataColumn("Id", Type.GetType("System.Int32")));
dt.Columns.Add(new DataColumn("Grade", Type.GetType("System.Int32")));
dt.Columns.Add(new DataColumn("Name", Type.GetType("System.String")));
DataRow dr = dt.NewRow();
dr[;
dr[;
dr["Name"] = "孙七";
dt.Rows.Add(dr);
ds.Tables.Add(dt);
ds.Tables[].TableName = "Student";//每张表为根节点下的第一个子节点
ds.WriteXml(fileName);
Linq to XML
通过linq操作XML上手快、操作方便
//查询
XDocument xdoc = XDocument.Load(fileName);
var query = from item in xdoc.Descendants("Item")
select new { Id = item.Attribute("Id").Value, Name = item.Value };
foreach (var item in query)
{
Console.WriteLine(item.Id + " " + item.Name);
}
//添加
XDocument xdoc = XDocument.Load(fileName);
XElement xele = new XElement("Item","吴十?");//创建节点
xele.SetAttributeValue();//设置节点特性值
xdoc.Element("Root").Add(xele);
xdoc.Save(fileName);
//删除
XDocument xdoc = XDocument.Load(fileName);
XElement xele = xdoc.Descendants(")).FirstOrDefault();
xele.Remove();
xdoc.Save(fileName);
//修改
XDocument xdoc = XDocument.Load(fileName);
XElement xele = xdoc.Descendants(")).FirstOrDefault();
xele.Value = "流年";
xdoc.Save(fileName);
XML序列化与反序列化
//序列化 , Grade = , Name = "王五" }; XmlSerializer serializer = new XmlSerializer(typeof(Student)); serializer.Serialize(Console.Out, student);
//反序列化
string input = "<?xml version=\"1.0\" encoding=\"gb2312\"?><student><Id> 1 </Id><Grade> 2 </Grade><Name> 李四 </Name></student>";
using (StringReader sr = new StringReader(input))
{
XmlSerializer serializer = new XmlSerializer(typeof(Student));
Student student = (Student)serializer.Deserialize(sr);
Console.WriteLine(student.Name);
}
扩展阅读
http://www.dotnetcurry.com/linq/564/linq-to-xml-tutorials-examples
http://www.tutorialspoint.com/linq/linq_xml.htm
https://msdn.microsoft.com/en-us/library/mt693062.aspx
http://broadcast.oreilly.com/2010/10/understanding-c-simple-linq-to.html
http://www.codeproject.com/Articles/24376/LINQ-to-XML
http://csharp.net-tutorials.com/xml/reading-xml-with-the-xmlreader-class/
https://msdn.microsoft.com/zh-cn/library/58a18dwa(v=vs.120).aspx
http://csharp.net-informations.com/xml/xml-de-serialization.htm
XML文档操作集锦(C#篇)的更多相关文章
- XML文档操作之JAXP下实现
JAXP是java API for xml PRocessing的缩写. 其API可以在javax.xml.parsers 这个包中找到.这个包向用户提供了两个最重要的工厂类,SAXParserFac ...
- 关于XML文档操作类
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.X ...
- xml文档操作
/** * */package com.gootrip.util; import java.io.ByteArrayOutputStream;import java.io.File;import ja ...
- C#XmlHelper帮助类操作Xml文档的通用方法汇总
前言 该篇文章主要总结的是自己平时工作中使用频率比较高的Xml文档操作的一些常用方法和收集网上写的比较好的一些通用Xml文档操作的方法(主要包括Xml序列化和反序列化,Xml文件读取,Xml文档节点内 ...
- 用ORM的思想操作XML文档,一个对象就搞定不要太简单。滚蛋吧!XmlDocument、XmlNode、Xml***……
大家有没有这样的感受,一涉及XML文档操作就得百度一遍.是不是非!常!烦!.各种类型,各种方法,更别提为了找到一个节点多费劲.本来想写个XML操作的工具方法,写了两行一想既然XML文档是有规律的,如果 ...
- XMLHelper类 源码(XML文档帮助类,静态方法,实现对XML文档的创建,及节点和属性的增、删、改、查)
以下是代码: using System; using System.Collections.Generic; using System.Linq; using System.Web; using Sy ...
- 【XML】利用Dom4j读取XML文档以及写入XML文档
Dom4j简介 dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的.dom4j是一个十分优秀的JavaXML API,具有性能优异.功能强大和极其易使用的特点,它的性能 ...
- 【JAVA与DOM4J实现对XML文档的CRUD操作】
一.简介 1.网上下载DOM4J 1.6.1压缩包,解压开之后,发现几个目录和一个jar文件,jar文件是必须的文件其它目录: docs目录:帮助文档的目录,单击index.html: Quick s ...
- C#操作XML文档---基础
增查改删代码如下 public void CreateXML() { XmlDocument xml = new XmlDocument(); xml.AppendChild(xml.CreateXm ...
随机推荐
- 初识Opserver,StackExchange的监控解决方案
Opserver是闻名遐迩的网站Stack Overflow的开源监控解决方案,由Stack Exchange发布.它基于.NET框架构建,这在监控工具领域有些与众不同. 旨在为每个受监控系统的健康状 ...
- 高灵活度,高适用性,高性能,轻量级的 ORM 实现
ORM(Object-Relational Mapping 对象关系映射),它的作用是在关系型数据库和业务实体对象之间作一个映射,目的是提供易于理解的模型化数据的方法. ORM虽然有诸多好处,但是在实 ...
- 辛巴学院-Unity-剑英陪你零基础学c#系列(二)顺序
这不是草稿 辛巴学院:正大光明的不务正业. 上一次的教程写出来之后,反馈还是挺多的,有很多都做了修改,也有一些让人崩溃,不得不说上几句.有些人有些很奇怪的地方,你写篇东西,被看了以后不说他感觉怎么 ...
- [ASP.NET MVC 大牛之路]01 - 开篇
匆匆2014,转眼就到末尾了.在这一年,你还有哪事情些想做而没有做? 2014年在我身上发生了两件意义重大的事,一是正月初一宝宝出生,我升级成为了爸爸:二是进入了一家创业公司,成为了技术负责人. 去年 ...
- C语言 · 删除数组0元素
从键盘读入n个整数放入数组中,编写函数CompactIntegers,删除数组中所有值为0的元素,其后元素向数组首端移动.注意,CompactIntegers函数需要接受数组及其元素个数作为参数,函数 ...
- 2013 duilib入门简明教程 -- VS环境配置(2)
既然是入门教程,那当然得基础点,因为搜索duilib相关资料时,发现有些小伙伴到处都是编译错误,以及路径配置错误等等,还有人不知道SVN,然后一个个文件手动下载的. 其实吧,duili ...
- Hibernate增删查改语句
我用的数据库是MySQL,实体类叫Product create table Product ( proId integer not null auto_increment, proName varch ...
- GitFlow
git工作流 始终保持有master分支(只要有目录,git就自动创建)和develop分支(手动创建) 一.主分支Master二.开发分支Develop三.临时性分支(最后发布要删除的)* 功能(f ...
- The currently selected variant "arm-debug" uses split APKs, but none of the 1 split apks are compatible with the current device with density "213" and ABIs "x86".
出现这种错误一般是在电脑上用模拟器运行APK的吧. 可以在build.gradle中这样配置下: android{ ... defaultConfig { applicationId "XX ...
- distribution 中一直在运行 waitfor delay @strdelaytime 语句
Replication 自动创建来一个 Job:Replication monitoring refresher for distribution,这个Agent执行一个sp: dbo.sp_repl ...