首先,预备下XML的基本知识
DOM(对象文档模型)。DOM可以以一种独立于平台和语言的方式修改一个文档的内容和结构。常见的技术有HTML DOM和XML DOM。DOM的设计初衷是为了让不同厂家的网页技术可以再浏览器端显示。
XML当然是一种读取解析修改存储文档的技术。不过,文档就是对象,文档可以转化为对象,对象也可以转化为文档,我们可以让对象支持序列化,这样就可以永久的保存它。
XML的竞争对手是JSON。JSON主要和JavaScript一起使用,存储JavaScript对象。XML有着丰富的编码工具,如DOM4J,JDOM等。这里的J可不是指JSON,而是指JAVA,也就是说,属于和本篇主要内容对立的JAVA和XML中将要讲到的。
在XML中,节点(node)并不一定是一个元素(element),但是元素一定是一个节点。NODE有如下类型:
Element,Text,Attribute,RootElement,Comment,Namespace等。
在C#中,XmlElement实际上是XmlNode的子类。实际上,XmlNode是一个不可实例化的抽象类。
方法一:
使用 XmlDocument:
XmlDocument类是.NET框架的DOC解析器。XmlDocument将XML视为树状结构,它装载XML文档,并在内存中构建该文档的树状结构。在System.Xml命名空间中。
public Boolean InitUserDefineParam()
{
//打开xml文档
doc = new XmlDocument();
try
{
doc.Load("../../UserDefineParam.xml");
}
catch (Exception e)
{
Console.WriteLine(e.Message);
return false;
}
//遍历所有Item节点并取得值
XmlElement root = doc.DocumentElement;
XmlNodeList allItemList = root.GetElementsByTagName("Item");
IEnumerator iEnum = allItemList.GetEnumerator();
while (iEnum.MoveNext())
{
XmlNode curItem = (XmlNode)iEnum.Current;//需要NT4.0版本支持
switch (curItem.Attributes.GetNamedItem("name").Value)
{
case "DataLayerName":break;
case "MachineLayerName": break;
case "ColorAdjustModuleName": break;
case "OpenGLModuleName":break;
case "ScreenResolution":break;
case "2DScanSizeX":
try
{
Data2DSizeX = Int32.Parse(curItem.InnerText);
}
catch (Exception e)
{
Console.WriteLine(e.Message);
return false;
}
break;
case "2DScanSizeY":
try
{
Data2DSizeY = Int32.Parse(curItem.InnerText);
}
catch (Exception e)
{
Console.WriteLine(e.Message);
return false;
}
break;
case "1DScanSizeL":
try
{
Data1DSizeL = Int32.Parse(curItem.InnerText);
}
catch (Exception e)
{
Console.WriteLine(e.Message);
return false;
}
break;
}
}
return true;
}
对应的XML文档如下:
<UserDefineParam>
<!--负责和界面相关的显示内容-->
<Genre name =" ">
<Item name="ScreenResolution">1500*900</Item>
</Genre>
<!--负责和数据相关的内容-->
<Genre name ="Data">
<Item name ="2DScanSizeX">256</Item>
<Item name ="2DScanSizeY">450</Item>
<Item name ="1DScanSizeL">200</Item>
</Genre>
</UserDefineParam>
方法二:使用XmlTextReader
提供以单项,快速,无缓冲的方式读取XML数据,这意味着你只能顺序读取,如果要读取一个元素,那么可能就要求重新打开磁盘读取一遍文件。在System.Xml命名空间中。
XmlTextReader reader = null;
try {
// Load the reader with the data file and ignore all white space nodes.
reader = new XmlTextReader(filename);
reader.WhitespaceHandling = WhitespaceHandling.None;
// Parse the file and display each of the nodes.
while (reader.Read()) {
switch (reader.NodeType) {
case XmlNodeType.Element:
Console.Write("<{0}>", reader.Name);
break;
case XmlNodeType.Text:
Console.Write(reader.Value);
break;
case XmlNodeType.CDATA:
Console.Write("<![CDATA[{0}]]>", reader.Value);
break;
case XmlNodeType.ProcessingInstruction:
Console.Write("<?{0} {1}?>", reader.Name, reader.Value);
break;
case XmlNodeType.Comment:
Console.Write("<!--{0}-->", reader.Value);
break;
case XmlNodeType.XmlDeclaration:
Console.Write("<?xml version='1.0'?>");
break;
case XmlNodeType.Document:
break;
case XmlNodeType.DocumentType:
Console.Write("<!DOCTYPE {0} [{1}]", reader.Name, reader.Value);
break;
case XmlNodeType.EntityReference:
Console.Write(reader.Name);
break;
case XmlNodeType.EndElement:
Console.Write("</{0}>", reader.Name);
break;
}
}
方法三:使用Linq to Xml
LINQ 语言集成查询,只使用在C#和VB中.主要分为LINQ TO XML和LINQ TO SQL。前者使用xml作为持久层,后者使用数据库作为持久层。除此之外,也可以用于访问内存中的数据集合(LINQ TO ENTITY)。通过开源框架,开发人员可以添加更多的数据源。LAMBDA表达式并不一定和LINQ相关。lambda适用于创建委托和表达式目录树类型的匿名函数。