【linq学习笔记】1、linq to xml

前端之家收集整理的这篇文章主要介绍了【linq学习笔记】1、linq to xml前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

项目有个奇葩的需求:之前是直接将异常信息alert到页面,user觉得有些代码的异常不应该弹出,比如空指针、内存溢出等等,取而代之是友好的提示。于是决定将异常类型和友好提示组合为一个标签,保存到xml里,再根据抛出的异常,查找应该弹出的友好提示。当然,后台还是要将真正有意义的异常写入log。

以前一直用传统方式读取xml,趁此机会学习下linq,索性写一个linq自学系列。其实linq学习应该从扩张方法、委托、匿名类...入手,其他相关的linq知识,我会一步一步补上。

接下来用一个小例子实现这样功能:向硬盘中写入一个xml文件,再读取,并修改某个标签的值。

1.写xml

public static void WriteXml()
        {
            var xDoc = new XDocument(new XElement("root",new XElement("mobile",//根节点
            new XElement("iPhone",//兄弟节点1
                new XText("iPhone6"),new XAttribute("color","土豪金")),new XElement("samsung","galaxy s6"))));//兄弟节点2
            xDoc.Save(Console.Out);//控制台输入xml
            xDoc.Save(@"E:\test1.xml",SaveOptions.None);//保存到路径,SaveOptions有三个参数
         }


控制台输入了xml文档,XDocument已经帮我们完成了xml格式化


同样也生成了xml文件

但是不知道为什么两种方式生成的编码方式不同


2.读xml

 public static void ReadXml()
        {     
            XDocument doc = XDocument.Load(@"E:\test1.xml");
            var text = from t in doc.Descendants("root").Descendants("mobile")//父节点
                       //也可以这样doc.Descendants("mobile")
                       select new
                       {
                           samsung = t.Element("samsung").Value,iphoneName = t.Element("iPhone").Value,iphoneColor = t.Element("iPhone").Attribute("color").Value
                       };
            foreach (var item in text)
            {
                Console.WriteLine("{0},{1}",item.samsung,item.iphoneColor);
            }
        }
xml文件encoding格式必须和web.config编码格式一致,不然会报错:读取xml给定的编码字符无效 原文链接:https://www.f2er.com/xml/296311.html

猜你在找的XML相关文章