在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#篇)的更多相关文章

  1. XML文档操作之JAXP下实现

    JAXP是java API for xml PRocessing的缩写. 其API可以在javax.xml.parsers 这个包中找到.这个包向用户提供了两个最重要的工厂类,SAXParserFac ...

  2. 关于XML文档操作类

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.X ...

  3. xml文档操作

    /** * */package com.gootrip.util; import java.io.ByteArrayOutputStream;import java.io.File;import ja ...

  4. C#XmlHelper帮助类操作Xml文档的通用方法汇总

    前言 该篇文章主要总结的是自己平时工作中使用频率比较高的Xml文档操作的一些常用方法和收集网上写的比较好的一些通用Xml文档操作的方法(主要包括Xml序列化和反序列化,Xml文件读取,Xml文档节点内 ...

  5. 用ORM的思想操作XML文档,一个对象就搞定不要太简单。滚蛋吧!XmlDocument、XmlNode、Xml***……

    大家有没有这样的感受,一涉及XML文档操作就得百度一遍.是不是非!常!烦!.各种类型,各种方法,更别提为了找到一个节点多费劲.本来想写个XML操作的工具方法,写了两行一想既然XML文档是有规律的,如果 ...

  6. XMLHelper类 源码(XML文档帮助类,静态方法,实现对XML文档的创建,及节点和属性的增、删、改、查)

    以下是代码: using System; using System.Collections.Generic; using System.Linq; using System.Web; using Sy ...

  7. 【XML】利用Dom4j读取XML文档以及写入XML文档

    Dom4j简介 dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的.dom4j是一个十分优秀的JavaXML API,具有性能优异.功能强大和极其易使用的特点,它的性能 ...

  8. 【JAVA与DOM4J实现对XML文档的CRUD操作】

    一.简介 1.网上下载DOM4J 1.6.1压缩包,解压开之后,发现几个目录和一个jar文件,jar文件是必须的文件其它目录: docs目录:帮助文档的目录,单击index.html: Quick s ...

  9. C#操作XML文档---基础

    增查改删代码如下 public void CreateXML() { XmlDocument xml = new XmlDocument(); xml.AppendChild(xml.CreateXm ...

随机推荐

  1. 梦想还需有,因它必实现——发现最新版iOS漏洞,OverSky团队专访

    梦想还需有,因它必实现——发现最新版iOS漏洞,OverSky团队专访    “成功了!”,随着一句欢呼声在阿里巴巴西溪园区传出,Cydia的图标出现在一部iOS9.3.4的iPhone6上并成功运行 ...

  2. 利用gulp解决前后端分离的header/footer引入问题

    在我们进行前后端完全分离的时候,有一个问题一直是挺头疼的,那就是公共header和footer的引入.在传统利用后端渲染的情况下,我们可以把header.footer写成两个单独的模板,然后用后端语言 ...

  3. 共享文件夹:The user has not been granted the requested logon type at this computer

    场景重现 今天做一个项目测试,要用到虚拟机,于是在虚拟机(XP 32)上新建了一个共享的文件夹.然后我在Win7 机器上访问它得到如下的error 消息:

  4. [转]各种移动GPU压缩纹理的使用方法

    介绍了各种移动设备所使用的GPU,以及各个GPU所支持的压缩纹理的格式和使用方法.1. 移动GPU大全 目前移动市场的GPU主要有四大厂商系列:1)Imagination Technologies的P ...

  5. Chrome 控制台新玩法-console显示图片以及为文字加样式

    有兴趣的同学可以文章最后的代码复制贴到控制台玩玩. Go for Code 在正常模式下,一般只能向console 控制台输出简单的文字信息.但为了把信息输出得更优雅更便于阅读,除了cosole.lo ...

  6. [ASP.NET MVC 小牛之路]05 - 使用 Ninject

    在[ASP.NET MVC 小牛之路]系列上一篇文章(依赖注入(DI)和Ninject)的末尾提到了在ASP.NET MVC中使用Ninject要做的两件事情,续这篇文章之后,本文将用一个实际的示例来 ...

  7. 《App研发录》面世

    古者富贵而名灭,不可胜记,唯倜傥非常之人称焉.故西伯拘而演<周易>,屈原放逐,乃赋<离骚>.文人雅士一次次的谱写着千古绝唱,而我亦不能免俗,也要附庸风雅,写一部前不见古人.后不 ...

  8. jquery颜色选择器

    本站下载 第二种:纯JAVASCRIPT: <html> <head> <meta http-equiv="Content-Type" content ...

  9. jQuery第二篇 (帅哥)

    1.1 jQuery操作DOM jQuery课程的目标:学会使用jQuery设计常见效果 选择器 基本选择器:#id ..class .element.* . 层级选择器: 空格.>.+.~ 基 ...

  10. 【解决】Word 在试图打开文件时遇到错误 请尝试下列方法:* xxx * xxx * xxx

    有好几种情况,我先说我的这个情况 1.word设置不当导致 看图: 然后就能打开了~ 2.word格式问题,比如原来是doc,被人手动改成docx~~~ 解决方法:改回来 3.word版本不兼容,比如 ...