c# 读取XML文件的示例

如下XML文件:(算是一个属性值比较多的xml文件。。。读取该Xml算是我在公司实际的一个任务)

<?xml version="1.0" encoding="UTF-8"?>
<serverset>
 <devset PrintNumber="1" ControlBarcode="" ControlEBarcode="" ControlPIX="" PrinterPort="0" isShowAreaName="0" PrinterPortData="127.0.0.1" SparePrinterNumber="1" SparePrinterNumber2="1" ProductionAreaName="1" PrintType="QT;1B;1K;1L;1M;" PrintDevType="0" logicalDpiW="" logicalDpiH="" Baudrate="4800" QZHEIGHT="1" QZwaittime="45" FILEwaittime="45" enablestwoway="1" CommandType="0"/>
 <devset PrintNumber="2" ControlBarcode="" ControlEBarcode="" ControlPIX="" PrinterPort="0" isShowAreaName="0" PrinterPortData="127.0.0.211" SparePrinterNumber="1" SparePrinterNumber2="1" ProductionAreaName="" PrintType="" PrintDevType="0" logicalDpiW="" logicalDpiH="" Baudrate="4800" QZHEIGHT="1" QZwaittime="45" FILEwaittime="45" enablestwoway="0" CommandType="0"/>
 <devset PrintNumber="3" ControlBarcode="" ControlEBarcode="" ControlPIX="" PrinterPort="0" isShowAreaName="0" PrinterPortData="127.0.0.3" SparePrinterNumber="1" SparePrinterNumber2="1" ProductionAreaName="" PrintType="" PrintDevType="0" logicalDpiW="" logicalDpiH="" Baudrate="4800" QZHEIGHT="1" QZwaittime="45" FILEwaittime="45" enablestwoway="0" CommandType="0"/>
 <devset PrintNumber="4" ControlBarcode="" ControlEBarcode="" ControlPIX="" PrinterPort="3" isShowAreaName="0" PrinterPortData="USB2" SparePrinterNumber="1" SparePrinterNumber2="1" ProductionAreaName="" PrintType="" PrintDevType="2" logicalDpiW="" logicalDpiH="" Baudrate="4800" QZHEIGHT="1" QZwaittime="45" FILEwaittime="45" enablestwoway="1" CommandType="0"/>
 <OrtherInfo printMode="1" PrintTimeConfig="5" FilterEmptyRows="0" PrintFilePath="D:/choice/ftp/tiktenPrint" BackFilePath="D:/choice/ftp/prnBakDir" readBOHPrintConfig="1" CondingFormat="0" isShowChangeBill="0" isRunUpgrade="0" SingleTurnSpaceTime="30" storeprnPath="127.0.0.1" FtpPort="" BCode="1020001" UploadVersionAddress="" UploadVersionPort="0"/>
</serverset>

创建一个类WriteXml用来封装读取Xml的和属性值方法:代码如下

class ReadXml
 {
  /// <summary>
  /// 第一根节点的属性
  /// </summary>
  public string PrintNumber { get; set; }
  public string ControlBarcode { get; set; }
  public string ControlEBarcode { get; set; }
  public string ControlPIX { get; set; }
  public string PrinterPort { get; set; }
  public string isShowAreaName { get; set; }
  public string PrinterPortData { get; set; }
  public string SparePrinterNumber { get; set; }
  public string SparePrinterNumber2 { get; set; }
  public string ProductionAreaName { get; set; }
  public string PrintType { get; set; }
  public string PrintDevType { get; set; }
  public string logicalDpiW { get; set; }
  public string logicalDpiH { get; set; }
  public string Baudrate { get; set; }
  public string QZHEIGHT { get; set; }
  public string QZwaittime { get; set; }
  public string FILEwaittime { get; set; }
  public string enablestwoway { get; set; }
  public string CommandType { get; set; }

  /// <summary>
  /// 第二根节点的属性
  /// </summary>

  public string printMode { get; set; }
  public string PrintTimeConfig { get; set; }
  public string FilterEmptyRows { get; set; }
  public string PrintFilePath { get; set; }
  public string BackFilePath { get; set; }
  public string readBOHPrintConfig { get; set; }
  public string CondingFormat { get; set; }
  public string isShowChangeBill { get; set; }
  public string isRunUpgrade { get; set; }
  public string SingleTurnSpaceTime { get; set; }
  public string storeprnPath { get; set; }
  public string FtpPort { get; set; }
  public string BCode { get; set; }
  public string UploadVersionAddress { get; set; }
  public string UploadVersionPort { get; set; }

  public void read()
  {
   XmlDocument xmlDoc = new XmlDocument();
   xmlDoc.Load(@"D:\Choic\PrintConfig.xml");//读取xml文件
   XmlNode xn = xmlDoc.SelectSingleNode("serverset");
   XmlNodeList xnlNL = xn.SelectNodes("devset");//得到根节点
   foreach (XmlNode xnl in xnlNL)//遍历devset
   {
    WriteAndRead wr = new WriteAndRead();
    XmlElement xe = (XmlElement)xnl;
    wr.PrintNumber = xe.GetAttribute("PrintNumber").ToString();
    wr.ControlBarcode = xe.GetAttribute("ControlBarcode").ToString();
    wr.ControlEBarcode = xe.GetAttribute("ControlEBarcode").ToString();
    wr.ControlPIX = xe.GetAttribute("ControlPIX").ToString();
    wr.PrinterPort = xe.GetAttribute("PrinterPort").ToString();
    wr.isShowAreaName = xe.GetAttribute("isShowAreaName").ToString();
    wr.PrinterPortData = xe.GetAttribute("PrinterPortData").ToString();
    wr.SparePrinterNumber = xe.GetAttribute("SparePrinterNumber").ToString();
    wr.SparePrinterNumber2 = xe.GetAttribute("SparePrinterNumber2").ToString();
    wr.ProductionAreaName = xe.GetAttribute("ProductionAreaName").ToString();
    wr.PrintType = xe.GetAttribute("PrintType").ToString();
    wr.PrintDevType = xe.GetAttribute("PrintDevType").ToString();
    wr.logicalDpiW = xe.GetAttribute("logicalDpiW").ToString();
    wr.logicalDpiH = xe.GetAttribute("logicalDpiH").ToString();
    wr.Baudrate = xe.GetAttribute("Baudrate").ToString();
    wr.QZHEIGHT = xe.GetAttribute("QZHEIGHT").ToString();
    wr.QZwaittime = xe.GetAttribute("QZwaittime").ToString();
    wr.FILEwaittime = xe.GetAttribute("FILEwaittime").ToString();
    wr.enablestwoway = xe.GetAttribute("enablestwoway").ToString();
    wr.CommandType = xe.GetAttribute("CommandType").ToString();

    Console.WriteLine("PrintNumber:" + wr.PrintNumber + "\tControlBarcode:" + wr.ControlBarcode + "\tControlEBarcode:" + wr.ControlEBarcode
     + "\tControlPIX:" + wr.ControlPIX + "\tPrinterPort:" + wr.PrinterPort + "\tisShowAreaName:" + wr.isShowAreaName + "\tPrinterPortData:"
     + wr.PrinterPortData + "\tSparePrinterNumber:" + wr.SparePrinterNumber + "\tSparePrinterNumber2:" + wr.SparePrinterNumber2
     + "\tProductionAreaName:" + wr.ProductionAreaName + "\tPrintType:" + wr.PrintType + "\tPrintDevType:" + wr.PrintDevType + "\tlogicalDpiW:"
     + wr.logicalDpiW + "\tlogicalDpiH:" + wr.logicalDpiH + "\tBaudrate:" + wr.Baudrate + "\tQZHEIGHT:" + wr.QZHEIGHT + "\tQZwaittime:" + wr.QZwaittime
     + "\tFILEwaittime:" + wr.FILEwaittime + "\tenablestwoway:" + wr.enablestwoway + "\tCommandType:" + wr.CommandType);
    Console.WriteLine();

   }

   XmlNodeList xnlNL1 = xn.SelectNodes("OrtherInfo");//得到第二个根节点
   foreach (XmlNode xnl in xnlNL1)//OrtherInfo
   {

    WriteAndRead wr = new WriteAndRead();
    XmlElement xe = (XmlElement)xnl;
    wr.printMode = xe.GetAttribute("printMode").ToString();
    wr.PrintTimeConfig = xe.GetAttribute("PrintTimeConfig").ToString();
    wr.FilterEmptyRows = xe.GetAttribute("FilterEmptyRows").ToString();
    wr.PrintFilePath = xe.GetAttribute("PrintFilePath").ToString();
    wr.BackFilePath = xe.GetAttribute("BackFilePath").ToString();
    wr.readBOHPrintConfig = xe.GetAttribute("readBOHPrintConfig").ToString();
    wr.CondingFormat = xe.GetAttribute("CondingFormat").ToString();
    wr.isShowChangeBill = xe.GetAttribute("isShowChangeBill").ToString();
    wr.isRunUpgrade = xe.GetAttribute("isRunUpgrade").ToString();
    wr.SingleTurnSpaceTime = xe.GetAttribute("SingleTurnSpaceTime").ToString();
    wr.storeprnPath = xe.GetAttribute("storeprnPath").ToString();
    wr.FtpPort = xe.GetAttribute("FtpPort").ToString();
    wr.UploadVersionAddress = xe.GetAttribute("UploadVersionAddress").ToString();
    wr.UploadVersionPort = xe.GetAttribute("UploadVersionPort").ToString();
    Console.WriteLine("printMode:" + wr.printMode + "\tPrintTimeConfig:" + wr.PrintTimeConfig + "\tFilterEmptyRows:" + wr.FilterEmptyRows
     + "\tPrintFilePath:" + wr.PrintFilePath + "\tBackFilePath:" + wr.BackFilePath + "\treadBOHPrintConfig:" + wr.readBOHPrintConfig
     + "\tCondingFormat:" + wr.CondingFormat + "\tisShowChangeBill:" + wr.isShowChangeBill + "\tisRunUpgrade:" + wr.isRunUpgrade + "\tSingleTurnSpaceTime:" +
     wr.SingleTurnSpaceTime + "\tstoreprnPath:" + wr.storeprnPath + "\tFtpPort:" + wr.FtpPort + "\tUploadVersionAddress:" + wr.UploadVersionAddress + "\tUploadVersionPort:" + wr.UploadVersionPort);
   }
  }

在控制台上运行。。

class Program
 {
  static void Main(string[] args)
  {
   ReadXml RX = new ReadeXml();
   RX.Read();
   Console.Read();
  }
 }

运行结果如下:

好了,以上就是读取该XML文件以及实际运行结果图。。。。。。。

大牛们就当看个笑话啦!当然有哪里不对的地方或者可以改进的方法可以提出来。。。。对于一些没用读取过XML文件的程序猿们。。可供参考

以上就是c# 读取XML文件的示例的详细内容,更多关于c# 读取xml的资料请关注我们其它相关文章!

(0)

相关推荐

  • C#实现XML文件读取

    本文实例为大家分享了C#实现XML文件读取的具体代码,供大家参考,具体内容如下 using System.Collections; using System.Collections.Generic; using System.IO; using System.Text; using System.Xml.Serialization; /// <summary> /// 工具类 /// </summary> public static class Tools { /// <su

  • C# 创建,读取,写入XML文件

    Xml文件如下: <?xml version="1.0" encoding="utf-8"?> <Advertisements> <Ad> <ImageUrl>001.jpg</ImageUrl> <NavigateUrl>001.aspx</NavigateUrl> <Impressions>10</Impressions> <Keyword>g

  • 详解C#借助.NET框架中的XmlTextReader类读取XML的方法

    XmlTextReader 提供对 XML 数据流的只进只读访问.当前节点指读取器定位到的节点.使用任何读方法推进读取器并且属性反映当前节点的值. 此类实现 XmlReader 并符合 W3C 可扩展标记语言 (XML) 1.0 和"XML 中的命名空间"建议.XmlTextReader 提供以下功能: 执行格式良好的 XML 的规则. XmlTextReader 不提供数据验证. 检查 DocumentType 节点是否是格式良好的.XmlTextReader 检查 DTD 的格式是

  • C#读取Excel并转化成XML的方法

    本文实例讲述了C#读取Excel并转化成Xml的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: XmlDocument excelData = new XmlDocument(); DataSet excelTableDataSet = new DataSet(); StreamReader excelContent = new StreamReader(excelFilePath, System.Text.Encoding.Default); string stringC

  • C#读取XML的三种实现方式

    前言 XML文件是一种常用的文件格式,例如WinForm里面的app.config以及Web程序中的web.config文件,还有许多重要的场所都有它的身影.(类似还有Json)微软也提供了一系列类库来倒帮助我们在应用程序中存储XML文件 在程序中访问进而操作XML文件一般有两种模型: DOM(文档对象模型):使用DOM的好处在于它允许编辑和更新XML文档,可以随机访问文档中的数据,可以使用XPath查询,但是,DOM的缺点在于它需要一次性的加载整个文档到内存中,对于大型的文档,这会造成资源问题

  • C#读取XML的CDATA节点内容实例详解

    首先看实例代码: 昨天读取了以下XML, 之前没有读取过类似的格式,用一种比较笨的方法读取的,记录下 <?xml version="1.0"?> <response> <srvver>1.0</srvver> <srvcode>000</srvcode> <payload> <param type="XML" key="data"> <![CDA

  • 详解c#读取XML的实例代码

    XML文件是一种常用的文件格式,例如WinForm里面的app.config以及Web程序中的web.config文件,还有许多重要的场所都有它的身影.Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具.XML是一种简单的数据存储语言,使用一系列简单的标记描述数据,而这些标记可以用方便的方式建立,虽然XML占用的空间比二进制数据要占用更多的空间,但XML极其简单易于掌握和使用.微软也提供了一系列类库来倒帮助我们在应用程序中存储XML文件. "在程序中访问

  • c#读取XML多级子节点

    话不多说,请看代码: string xmlFilePath = "D:\\log_xml\\MarInfo.xml"; //Server.MapPath(@"相对路径如/xml/test.xml"); XmlDocument doc = new XmlDocument(); doc.Load(xmlFilePath);//加载XML文件 string rst = ""; //使用xpath表达式选择文档中所有的student子节点 XmlNode

  • C#读取xml节点数据方法小结

    本文实例总结了C#读取xml节点数据的方法.分享给大家供大家参考.具体如下: 第一种: 使用XPath XML的路径我配置在web.config 的appSettings节点下 <appSettings> <add key="orgCodePath" value="../../template/home/orgCode.xml"/> </appSettings> XML结构如下: <?xml version="1.

  • C#保存与读取DataTable信息到XML格式的方法

    本文实例讲述了C#保存与读取DataTable信息到XML格式的方法.分享给大家供大家参考.具体如下: 这里主要实现: 1.将DataTable中的信息保存到XML中 2.将以上述格式在XML中保存的信息读取到DataTable内 一.将DataTable的内容写入到XML文件中 /// <summary> /// 将DataTable的内容写入到XML文件中 /// </summary> /// <param name="dt">数据源</p

  • C#中如何使用 XmlReader 读取XML文件

    XmlReader通过向前读取文档并识别读取到的元素,为我们提供了一种消耗资源最少的方式来解析XML数据.很多时候我们都是利用XmlReader来对XML文件的数据有效性进行验证(使用XmlReader实例的Read()方法依次读取所有节点,以此判断是否与符合指定的模式).使用这种非缓存.只读.只向前的方式,每次读取只将很少的数据放入内存,对内存的占用量较小,对于读取内容较大的XML文件不失为一种最佳的选择. 让我们看看XmlReader类读取XML文件的步骤: 1.使用XmlReader类的C

  • C# winfrom实现读取修改xml

    本文示例为大家分享了winfrom实现读取修改xml的具体代码,供大家参考,具体内容如下 在winfrom窗体中放一个文本框,2个按钮,一个panle,如下图 form.cs文件中的代码: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text;

  • C#从文件流读取xml文件到DataSet并显示的方法

    本文实例讲述了C#从文件流读取xml文件到DataSet并显示的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: DataSet ds= new DataSet (); FileStream fs = new FileStream (Server.MapPath=("somexml.xml"),FileMode.Open,FileAccess.Read); ds.ReadXml (fs); DataGrid1.DataSource = ds; DataGrid1.D

随机推荐