C#和XML

首先,预备下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适用于创建委托和表达式目录树类型的匿名函数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值