• XML的序列化读取方式


    在CSDN上,很多朋友会问,C#中如何读取XML文件?如何读取最快?我的回答是,使用XmlTextReader读取的速度是最快的。但也不乏一些效率稍低但也非常有效的读取方式,比如序列化方式。这里详细介绍一下步骤吧。

    1. 使用Visual Studio的CreateSchema工具,或者XMLSpy等第三方的工具,打开需要读取的XML文件,并创建XSD(推荐使用Visual Studio自带的工具)
      比如我有个文件是students.xml,内容如下:
       
      <?xml version="1.0" encoding="utf-8"?>
      <students>
        <student name="Sunny Chen" age="29">
          <registered>true</registered>
        </student>
        <student name="Kitty Wang" age="28">
          <registered>false</registered>
        </student>
      </students>
      

      在使用工具生成xsd以后,获得students.xsd内容如下:
    2. <?xml version="1.0" encoding="utf-8"?>
      <xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
        <xs:element name="students">
          <xs:complexType>
            <xs:sequence>
              <xs:element maxOccurs="unbounded" name="student">
                <xs:complexType>
                  <xs:sequence>
                    <xs:element name="registered" type="xs:boolean" />
                  </xs:sequence>
                  <xs:attribute name="name" type="xs:string" use="required" />
                  <xs:attribute name="age" type="xs:unsignedByte" use="required" />
                </xs:complexType>
              </xs:element>
            </xs:sequence>
          </xs:complexType>
        </xs:element>
      </xs:schema>
    3. 使用xsd.exe生成类文件,如下:
    4. 将生成的students.cs文件添加到你的项目中。此时如果你的xsd文件和这个cs文件在相同目录下,那么在你的“解决方案资源管理器”中,会将两者关联起来
    5. 使用下面的代码读取你的students.xml文件:
    6. using System;
      using System.IO;
      using System.Xml.Serialization;
      
      namespace XmlRead
      {
          class Program
          {
              static void Main(string[] args)
              {
                  XmlSerializer serializer = new XmlSerializer(typeof(students));
                  using (FileStream fs = new FileStream(@"c:\students.xml", FileMode.Open))
                  {
                      students studs = (students)serializer.Deserialize(fs);
                      foreach (var stud in studs.student)
                      {
                          Console.WriteLine("{0}: Age = {1}, Registered = {2}", 
                              stud.name, 
                              stud.age, 
                              stud.registered);
                      }
                      fs.Close();
                  }
              }
          }
      }
    7. 获得的结果如下:
  • 相关阅读:
    扫描线算法
    [Baltic 2001]Mars Maps
    Lost Cow
    李超线段树
    多种方法求解Pku3468 A Simple Problem with Integers
    陈老师的福利
    leetcode 673. 最长递增子序列的个数
    #10043.「一本通 2.2 例 1」剪花布条
    PTA7-1
    6-1 实验三哈夫曼树 (15分)
  • 原文地址:https://www.cnblogs.com/daxnet/p/1686957.html
Copyright © 2020-2023  润新知