1、操作XML文档的两种常用方式:

1)使用XmlReader类和XmlWriter类操作

 XmlReader是基于数据流的,占用极少的内存,是只读方式的,所以速度极快.只能采用遍历的模式查找数据节点。

(1)创建XmlReader对象:使用XmlReader的静态方法Create创建。以下为该方法的各种重载版本。

   public static XmlReader Create(TextReader input);//通过TextReader对象创建
       public static XmlReader Create(string inputUri);//通过xml文档路径创建
       public static XmlReader Create(Stream input, XmlReaderSettings settings);//通过流对象创建
       public static XmlReader Create(TextReader input, XmlReaderSettings settings);
       public static XmlReader Create(string inputUri, XmlReaderSettings settings);
       public static XmlReader Create(XmlReader reader, XmlReaderSettings settings);
       public static XmlReader Create(Stream input, XmlReaderSettings settings, string baseUri);
       public static XmlReader Create(Stream input, XmlReaderSettings settings, XmlParserContext inputContext);
       public static XmlReader Create(TextReader input, XmlReaderSettings settings, string baseUri);
       public static XmlReader Create(TextReader input, XmlReaderSettings settings, XmlParserContext inputContext);
       public static XmlReader Create(string inputUri, XmlReaderSettings settings, XmlParserContext inputContext);

(2)遍历文档:有好几种方式,一般以Read()方法开始遍历,Read方法可以进入读取完当前节点后,可以自动进入下一节点,然后可以通过HasValue判断该节点是否有值,通过HasAttribute判断是否有属性值

  XmlReader reader = XmlReader.Create("myXmldocument.xml");
      while (reader.Read())
      {
        if (reader.NodeType == XmlNodeType.Element)
         {...}

   if (reader.HasValue)
         {...}
        if (reader.HasAttributes)
         {...}
      }

(3)读取节点的数据:通过XmlReader对象的各个属性、方法获取,具体可查看msdn。如可通过Value属性获取当前节点的值,通过ReadElementString()返回文本,也可通过ReadElementContentAs的几个版本获取,并强制转换为对应的类型,如ReadElementContentAsString()、ReadElementContentAsDouble()....等方法.

  XmlReader reader = XmlReader.Create("myXmldocument.xml");

  string valueStr=String.Empty;
      while (!reader.EOF)
      {
         if (reader.MoveToContent() == XmlNodeType.Element && reader.Name == "title")
          {
              valueStr=reader.ReadElementString() ;
          }
          else
          {
              reader.Read();
          }
      }

XmlWriter 是一个提供一种快速、非缓存和只进的方式来生成包含 XML 数据的流或文件的类,常用用法如下。

XmlWriter xmlWriter = XmlWriter.Create("myconfig.xml");//创建xmlwriter对象
xmlWriter.WriteStartDocument();//开始写xml文档
xmlWriter.WriteStartElement("AlgorithmData");//写入元素
xmlWriter.WriteStartAttribute("AlgorithmTypeId");    //写入AlgorithmData的属性AlgorithmTypeId的属性名
xmlWriter.WriteValue("1");  //写入AlgorithmData的属性AlgorithmTypeId的属性值
.....其他属性的写入
xmlWriter.WriteEndElement();//结束AlgorithmData节点的写入
.....其他节点的写入
xmlWriter.WriteEndDocument();//结束文档的写入
xmlWriter.Flush();//将XML文档写入磁盘
xmlWriter.Close();//关闭XML文档

2)使用XDocument类操作

XmlDocument是基于树形结构的模型,数据保存于内存中,可以查找内存中数据的任何节点的数据。占用内存大,处理方便,可读可写,几乎想当于一次把Xml读入内存.

以下是读取xml文档的示例,该类的具体api详见msdn的接口描述: https://msdn.microsoft.com/zh-cn/library/system.xml.linq.xdocument_methods(v=vs.100).aspx

try
{
  List<AlgorithmData> algorithmDataList = new List<AlgorithmData>();
  XDocument xd = XDocument.Load(configPath);//加载xml文档   var root = xd.Root;//读取根节点
  var rootXElements = root.Elements("AlgorithmData");//获取根节点下所有AlgorithmData节点
  foreach (XElement element in rootXElements)//循环读取AlgorithmData节点列表
  {
    AlgorithmData model = new AlgorithmData();     model.TargetSceneTypeId = int.Parse(element.Attribute("TargetSceneTypeId").Value);//读取节点属性
    model.AlgorithmSceneName = element.Attribute("AlgorithmSceneName").Value;
    model.AlgorithmTypeId = int.Parse(element.Attribute("AlgorithmTypeId").Value);
    string[] detectRegionTypeStringArray = element.Attribute("DetectRegionTypeList").Value.Split(',');
    List<int> detectRegionTypeList = new List<int>();
    foreach(string str in detectRegionTypeStringArray)
    {
      detectRegionTypeList.Add(int.Parse(str));
    }
    model.DetectRegionTypeList = detectRegionTypeList;
    model.IsUseable = bool.Parse(element.Attribute("IsUseable").Value);
    algorithmDataList.Add(model);
  }   return algorithmDataList;
}
catch (Exception ex)
{
  throw ex;
}

  

操作xml文档的常用方式的更多相关文章

  1. 操作XML文档遇到的XMLNS问题及解决方法 (C# 和 PHP)

    原文:操作XML文档遇到的XMLNS问题及解决方法 (C# 和 PHP) 不管是用 PHP 还是 C#, 在操作 XML 的时候我们除了一个节点一个节点去取值之外, 还有一个非常方便的表达式, 就是 ...

  2. 文档对象模型操作xml文档

    简介 :文档对象模型(DOM)是一种用于处理xml文档的API函数集. 2.1文档对象模型概述 按照W3C的定义,DOM是“一种允许程序或脚本动态地访问更新文档内容,结构和样式的.独立于平台和语言的规 ...

  3. C# 操作XML文档 使用XmlDocument类方法

    W3C制定了XML DOM标准.很多编程语言中多提供了支持W3C XML DOM标准的API.我在之前的文章中介绍过如何使用Javascript对XML文档进行加载与查询.在本文中,我来介绍一下.Ne ...

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

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

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

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

  6. C#XmlHelper操作Xml文档的帮助类

    using System.Xml; using System.Data; namespace DotNet.Utilities { /// <summary> /// Xml的操作公共类 ...

  7. XPath操作XML文档

    NET框架下的Sytem.Xml.XPath命名空间提供了一系列的类,允许应用XPath数据模式查询和展示XML文档数据. 3.1XPath介绍 主要的目的是在xml1.0和1.1文档节点树种定位节点 ...

  8. [XML] C# XmlHelper操作Xml文档的帮助类 (转载)

    点击下载 XmlHelper.rar 主要功能如下所示 /// <summary> /// 类说明:XmlHelper /// 编 码 人:苏飞 /// 联系方式:361983679 // ...

  9. C#操作XML文档(XmlDocument、XmlNode、XmlAttribute、SelectSingleNode、SelectNodes、XmlNodeList)

    XML文档是一种通用的文档,这种文档既可以用.config作为后缀也可以用.xml作为后缀.XML文档主要由元素节点和节点的属性共同构成的.它有且仅有一个根节点,其他的节点全部都是根节点的子节点或者子 ...

随机推荐

  1. Jordan Lecture Note-11: 典型相关分析(Canonical Correlation Analysis, CCA).

    典型相关分析 (一)引入 典型相关分析(Canonical Correlation Analysis)是研究两组变量之间相关关系的一种多元统计方法.他能够揭示出两组变量之间的内在联系. 我们知道,在一 ...

  2. JDK1.6官方下载_JDK6官方下载_JDK1.6API(chm)下载_JDK6APICHM中文参

    JDK1.6官方下载_JDK6官方下载地址:http://www.java.net/download/jdk6/6u10/promoted/b32/binaries/jdk-6u10-rc2-bin- ...

  3. Helpers\SimpleCurl

    Helpers\SimpleCurl The SimpleCurl class is there to curl data from RESTful services. A lot of compan ...

  4. Eclipse的java代码出错:The import org.apache cannot be resolved

    Eclipse中,折腾java代码. 把之前在android中的代码拿过来使用. 结果出现The import org.apache cannot be resolved的错误: [解决过程] 1.这 ...

  5. PHP.2-LAMP平台介绍及网站的工作原理

    LAMP平台介绍及网站的工作原理 1.HTTP协议 URL(UniformResourceLocator)统一资源定位符,就是网页地址的意思.[格式:协议://主机.端口.文件.附加资源] ##URL ...

  6. 使用JS制作一个鼠标可拖的DIV(一)——鼠标拖动

    使用 JS 来实现一个可拖动的DIV,主要是使用到以下几个事件: 1.鼠标按下:DIV元素的onmousedown. 2.鼠标按住拖动:document 的 onmousemove 元素. 3.鼠标放 ...

  7. MYSQL基础笔记(一)

    关系型数据库概念: 1.什么是关系型数据库? 关系型数据库:是一种建立在关系模型(数学模型)上的数据库 关系模型:一种所谓建立在关系上的模型. 关系模型包含三个方面: 1.数据结构:数据存储的问题,二 ...

  8. SSIS 学习(5):容器【转】

    容器是Integration Services 包中非常重要的一部分功能,它可以对控制流中的任务进行直观的划分与组织,使包的结构简明扼要.易于管理.易于维护. 在Integration Service ...

  9. ECharts地图详解 【转】

    $(function() { // 路径配置 require.config({ paths : { // echarts: 'http://echarts.baidu.com/build/dist' ...

  10. Ajax返回xml类型数据

    ajax可以返回文本类型数据和xml类型数据,xml是计算机通用语言 可以使用js解析返回xml类型数据的dom对象 前端页面 <!doctype html> <html lang= ...