zoukankan      html  css  js  c++  java
  • 操作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
            }
  • 相关阅读:
    SVO深度解析(三)之深度滤波(建图部分)
    SVO深度解析(二)之跟踪部分
    SVO深度解析(一)之简介和评价
    图像三维重建方法综述
    SLAM优化位姿时,误差函数的雅可比矩阵的推导。
    Canny边缘检测原理与C++实现(2)实现部分
    Canny边缘检测原理与C++实现(1)原理部分
    指针的大小是谁决定的
    Ubuntu 16.04配置CUDA 9.0+cudnn 7.0以及解决Nvidia显卡导致黑屏问题
    安装FAB-Map 2.0,Ubtuntu 16.04
  • 原文地址:https://www.cnblogs.com/yaoxing92/p/3858179.html
Copyright © 2011-2022 走看看