操作xml练习

案例1:获取指定节点的内容


public void XmlTest() { string xmlFileName=AppDomain.CurrentDomain.BaseDirectory+"\book.xml"; if (File.Exists(xmlFileName)) { XmlReader xmlReader = XmlReader.Create(xmlFileName); while (!xmlReader.EOF) //判断是否是流结尾 { if (xmlReader.MoveToContent() == XmlNodeType.Element && xmlReader.Name == "title") //MoveToContent()检测是否是内容节点,如果不是则后移下一个节点。 XmlNodeType.Element表示特征类型,特性(例如,id='123')。 { Console.WriteLine(xmlReader.ReadElementString());//获取当前节点的内容 } else { xmlReader.Read(); //Read()方法:循环下一个节点 } } } }

案例2:获取数据后数据转换使用ReadElementContentAsInt()、ReadElementContentAsDateTime()、ReadElementContentAsDouble()等方法,这样比先获取该值字符串再转换成其他数据类型的方法效率较高。

案例3:写入xml文件(会覆盖)

 public void XmlWriteTest()
        {
            string xmlFileName = AppDomain.CurrentDomain.BaseDirectory + "\newBook.xml";
                XmlWriterSettings settings = new XmlWriterSettings();
                settings.Indent = true;   //是否缩进
                settings.NewLineOnAttributes = true;   //是否将属性写入新行
                XmlWriter writer = XmlWriter.Create(xmlFileName, settings);   //静态方法实例化XmlWriter对象. XmlWriter会用新文件覆盖已有文件
                writer.WriteStartDocument();  //声明xml为1.0的版本号
                writer.WriteComment("这是一个注释");   //插入注释
                writer.WriteStartElement("book");  //父节点名称
                writer.WriteAttributeString("title", "New China");  //父节点的特征
                writer.WriteAttributeString("author", "heyaoxing"); //父节点的特征
                writer.WriteElementString("what", "I don't konw!"); //父节点的特征
                writer.WriteStartElement("begin");   //子节点
                writer.WriteElementString("beginItem", "asdasd"); //子节点下的内容节点和内容
                writer.WriteEndElement();      //子节点的结束标签
                writer.WriteElementString("name","234sdf"); //父节点的内容标签和内容
                writer.WriteEndElement();     //父节点结束标签
                writer.WriteEndDocument();    //声明结束文档
                writer.Flush();      //将缓存数据写入流,同时清除当前缓存缓存数据
                writer.Dispose();   //清除 witer对象
        }

案例4:DataSet数据转换成Xml数据

public void DataSetToXmlTest()
        {
            string xmlFileName = AppDomain.CurrentDomain.BaseDirectory + "\book.xml";
            string connecString = @"Data Source=(local);Initial Catalog=TestWeb1;User ID=ca;Password=123456";
            string sqlString="SELECT TOP 1000 [USR_ID],[FAMILY_ID],[NAME],[RELATION] FROM [TestWeb1].[dbo].[USERS_FAMILY]";
            using (SqlConnection con = new SqlConnection(connecString))
            {
                SqlDataAdapter da = new SqlDataAdapter(sqlString, con);
                DataSet ds = new DataSet("USERS_FAMILY");
                da.Fill(ds,"USERS_FAMILY");
                ds.WriteXml(xmlFileName, XmlWriteMode.WriteSchema); //将当前内容以xml形式写入DataSet
                XmlDataDocument doc = new XmlDataDocument(ds);  //将当前DataSet写入到Xml
                ds.Dispose();
                da.Dispose();
            }
        }

案例5:序列化和反序列化

public void XmlSerTest()
        {
            Project project = new Project();
            project.name = "yaoxing";
            project.age = 23;
            project.sex = "";
            project.address = "珠海市";
            //序列化操作
            TextWriter textWriter = new StreamWriter("project.xml"); //创建写入流对象
            XmlSerializer sr = new XmlSerializer(typeof(Project));  //实例化XmlSerializer,同时XmlSerializer需要知道序列号的对象
            sr.Serialize(textWriter, project);  //执行序列化操作
            textWriter.Dispose();

            //反序列化
            FileStream file = new FileStream("project.xml", FileMode.Open);  //创建文件对象
            XmlSerializer xsr = new XmlSerializer(typeof(Project));
            Project pro = (Project)xsr.Deserialize(file);  //执行反序列化操作
            Console.WriteLine(pro.name);
            Console.WriteLine(pro.age);
            Console.WriteLine(pro.sex);
            Console.WriteLine(pro.address);
        }

案例6:XML To Linq

 public void LinqToXmlTest()
        {
            string xmlFileName = AppDomain.CurrentDomain.BaseDirectory + "project.xml";
            if (File.Exists(xmlFileName))
            {
                XDocument xdoc = XDocument.Load(xmlFileName); //加载指定xml文件
                Console.WriteLine("" + xdoc.LastNode.ToString());  //获取最后一个子节点的值
                //Linq查询xml文档
                var name = from a in xdoc.Descendants("name")     //使用Linq查询方式1
                           select a.Value;

                Console.WriteLine(xdoc.Element("Project").Element("age").Value);     //使用Linq查询方式2
                Console.WriteLine(name.Count());
                foreach (var item in name)
                {
                    Console.WriteLine(item);
                }
            }

            XDocument xd = new XDocument();
            XComment xc = new XComment("这是一条注释");
            xd.Add(xc);                                //插入注释
            XNamespace ns = "http://www.baidu.com/";  //定义命名空间
            XElement xl = new XElement(ns + "company",  //定义节点
               new XAttribute("key","num1"),             //定义特性
                new XElement("partMent",                //定义节点
                    new XElement("name", "online")     //定义节点
                    ),
                new XComment("中间插入一条注释"),    //插入注释
                new XElement("sunlike", "name"),    //定义节点
                new XElement("sunlike", "name"),    //定义节点
                new XElement("sunlike", "name"),    //定义节点
                new XElement("sunlike", "name")    //定义节点
                );
            xd.Add(xl);          //定义节点载入文件
            xd.Save("company.xml");           //保存xml
        }
原文地址:https://www.cnblogs.com/yaoxing92/p/3858179.html