• C#生成XML的三种途径


    为了全面,这里都将XML保存到文件中,有三种生成XML的方式:
    1。我认为是最原始,最基本的一种:利用XmlDocument向一个XML文件里写节点,然后再利用XmlDocument保存文件。
        首先加载要写入的XML文件,但是如果没有的,就要新建,在新建的过程中,要有写入的代码;   

                XmlDocument doc = new XmlDocument();
                try
                {
                    doc.Load("new.xml");
                }
                catch
                {
                    XmlTextWriter xtw = new XmlTextWriter("new.xml", Encoding.UTF8);   新建XML文件
                    xtw.WriteStartDocument();
                        xtw.WriteStartElement("gnode");                  gnode根节点
                              xtw.WriteStartElement("myxm1");                 gnode根节点下的元素myxmls
                              xtw.WriteEndElement();
                        xtw.WriteEndElement();
                    xtw.WriteEndDocument();
                    xtw.Close();
                    doc.Load("new.xml");               
                }           
               
                XmlNode xn = doc.DocumentElement;                   找到根节点
                XmlElement xe = doc.CreateElement("myxml2");             在根节点下创建元素,如果是属性,则用XmlAttribute
                xe.InnerText = "hahaha";                                             给子节点写入文本节点(值)
                xn.AppendChild(xe);                                            根节点将其纳入
                doc.Save("new2.xml");                          利用XmlDocument保存文件

    注意点:在新建根节点的时候,WriteStartElement,只能嵌套,也就是只能有一个根节点。

    2。应用到数据库,将数据库的DataSet对象里的值来生成XML文件的元素;

        using (SqlConnection con = new SqlConnection("Server=.;DataBase=HGSTUDY;uid=sa;pwd=yao"))
                {
                    con.Open();
                    SqlCommand command = new SqlCommand("select * from GL_STUDY", con);
                    command.CommandType = CommandType.Text;
                    DataSet ds = new DataSet("DATASET");          DATASET将成为XML文件中的根节点名称,否则系统将其命名为NewDataSet
                    SqlDataAdapter sda = new SqlDataAdapter();
                    sda.SelectCommand = command;
                    sda.Fill(ds, "DATATABLE");                         DATATABLE为所生成XML文件中的子节点名称,否则系统将其命名为Table。
                    ds.WriteXml("dbxml.xml");               DataSet的方法WriteXml将数据写入到XML文件,就是这么一句话。如果不保存到文件,直接ds.GetXML()
                }

    3。利用XmlSerializer来将类的属性值转换为XML文件的元素值。用一个字符串作为一个XML文档中的xmlAttribute或xmlElement。[其元素或属性由类的定义来设置(xml串行化)]

    using System;System.xml.Serialization;

    3.1.先初始化一个类,设置属性值

    [XmlRoot("Truck")] ----设置作为XML中的根元素名称
        public Truck()
            { }       
            [XmlAttribute("id")] --------设置作为xml中的属性
            public int ID
            {
                get{return this._id;}
                set { this._id = value; }
            }
            [XmlElement("chepai")]------设置作为XML中的元素(默认状态)
            public string cheID
            {
                get { return this._cheID; }
                set { this._cheID = value; }
            }
            private int _id = 0;
            private string _cheID = "";
       

    3.2.创建XmlSerializer实例

    class XXX
    {
          XmlSerializer ser = new XmlSerializer(Type.GetType("forxml.truck"));
                Truck tr = new Truck();
                tr.ID = 1;
                tr.cheID = "赣A T34923";

    3.3.Serialize方法--完成对类的串行化
                XmlTextWriter xtw = new XmlTextWriter("myxml.xml",Encoding.UTF8);          用XmlTextWriter 创建一个XML文件
                ser.Serialize(xtw, tr);                如果只想显示,可以直接ser.Serialize(Console.Out, tr); 

    }

    个人总结,这里只叙述了三种方法,灵活应用后会很好,直接输入,或通过数据库或类都可以。可以用来在C#中对XML的生成。

  • 相关阅读:
    Fiddler无法抓取HTTPS的问题,Fiddler证书无法安装终极解决方案,
    锤子手机做appium自动化测试时,运行脚本总是弹出警告框的问题
    jmeter4+win10+jdk1.8环境下,jmeter输入中文就卡死的问题
    jenkins构建邮件自动发送,测试邮件发送成功,构建项目邮件发送不成功的问题
    Jenkins安装部署
    Appium中wait_activity的使用以及XPATH定位
    Appium连接夜神模拟器,模拟手势点击(tap)
    Appium如何查看webview上元素
    Appium启动淘宝APP,输入搜索内容
    Error while obtaining UI hierarchy XML file: com.android.ddmlib.SyncException: Remote object doesn't
  • 原文地址:https://www.cnblogs.com/winvay/p/1321400.html
Copyright © 2020-2023  润新知