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;
}