操作xml文档的常用方式
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文档的常用方式的更多相关文章
- 操作XML文档遇到的XMLNS问题及解决方法 (C# 和 PHP)
原文:操作XML文档遇到的XMLNS问题及解决方法 (C# 和 PHP) 不管是用 PHP 还是 C#, 在操作 XML 的时候我们除了一个节点一个节点去取值之外, 还有一个非常方便的表达式, 就是 ...
- 文档对象模型操作xml文档
简介 :文档对象模型(DOM)是一种用于处理xml文档的API函数集. 2.1文档对象模型概述 按照W3C的定义,DOM是“一种允许程序或脚本动态地访问更新文档内容,结构和样式的.独立于平台和语言的规 ...
- C# 操作XML文档 使用XmlDocument类方法
W3C制定了XML DOM标准.很多编程语言中多提供了支持W3C XML DOM标准的API.我在之前的文章中介绍过如何使用Javascript对XML文档进行加载与查询.在本文中,我来介绍一下.Ne ...
- 用ORM的思想操作XML文档,一个对象就搞定不要太简单。滚蛋吧!XmlDocument、XmlNode、Xml***……
大家有没有这样的感受,一涉及XML文档操作就得百度一遍.是不是非!常!烦!.各种类型,各种方法,更别提为了找到一个节点多费劲.本来想写个XML操作的工具方法,写了两行一想既然XML文档是有规律的,如果 ...
- C#操作XML文档---基础
增查改删代码如下 public void CreateXML() { XmlDocument xml = new XmlDocument(); xml.AppendChild(xml.CreateXm ...
- C#XmlHelper操作Xml文档的帮助类
using System.Xml; using System.Data; namespace DotNet.Utilities { /// <summary> /// Xml的操作公共类 ...
- XPath操作XML文档
NET框架下的Sytem.Xml.XPath命名空间提供了一系列的类,允许应用XPath数据模式查询和展示XML文档数据. 3.1XPath介绍 主要的目的是在xml1.0和1.1文档节点树种定位节点 ...
- [XML] C# XmlHelper操作Xml文档的帮助类 (转载)
点击下载 XmlHelper.rar 主要功能如下所示 /// <summary> /// 类说明:XmlHelper /// 编 码 人:苏飞 /// 联系方式:361983679 // ...
- C#操作XML文档(XmlDocument、XmlNode、XmlAttribute、SelectSingleNode、SelectNodes、XmlNodeList)
XML文档是一种通用的文档,这种文档既可以用.config作为后缀也可以用.xml作为后缀.XML文档主要由元素节点和节点的属性共同构成的.它有且仅有一个根节点,其他的节点全部都是根节点的子节点或者子 ...
随机推荐
- 如何获取input自定义属性
javascript方法: <input type="checkbox" name="sdf" data="这是自定义属性" /& ...
- HBase Error: connection object not serializable
HBase Error: connection object not serializable 想在spark driver程序中连接HBase数据库,并将数据插入到HBase,但是在spark集群提 ...
- tornado简单的验证码
1.html代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...
- 关于JAVA那点事---i++和++i
对i++和++i 一直有点晕,今天专门抽空来研究相关的知识. 先从简单的说起. 有如下程序: int i=0; i=i++; system.out.print(i); 一眼望去这个结果显而易见是1,但 ...
- 给jdk写注释系列之jdk1.6容器(11)-Queue之ArrayDeque源码解析
前面讲了Stack是一种先进后出的数据结构:栈,那么对应的Queue是一种先进先出(First In First Out)的数据结构:队列. 对比一下Stack,Queue是一种先进先出的容 ...
- [改善Java代码]适时选择不同的线程池来实现
Java的线程池实现从最根本上来说只有两个:ThreadPoolExecutor类和ScheduledThreadPoolExecutor类,这两个类还是父子关系,但是Java为了简化并行计算,还提供 ...
- 关于Windows下mysql忘记root密码的解决方法
原文链接: http://www.cnblogs.com/andy_tigger/archive/2012/04/12/2443652.html 1. 首先检查mysql服务是否启动,若已启动则先将其 ...
- 使用 autoconf
在此之前先说一下autooconf在linux下安装的问题,因为不知道怎么安装,我就直接在终端上输入autoconf,结果它会提示是否安装它,下面还有指定安装的方法,我 就直接输入,是什么命令记不住了 ...
- poj 3254 状态压缩DP
思路:把每行的数当做是一个二进制串,0不变,1变或不变,找出所有的合法二进制形式表示的整数,即相邻不同为1,那么第i-1行与第i行的状态转移方程为dp[i][j]+=dp[i-1][k]: 这个方程得 ...
- poj 3249 拓扑排序 and 动态规划
思路:我们首先来一遍拓扑排序,将点按先后顺序排列于一维数组中,然后扫描一遍数组,将每个点的出边所连接的点进行更新,即可得到最优解. #include<iostream> #include& ...