C#读取XML中元素和属性值的实现代码

 更新时间:2013年04月11日 15:58:34   作者:  
用C#读取xml有很多方式,这里我就先使用XmlDocument读取Xml,用一段代码遍历所有元素,并打印student的所有属性和子节点的值

1、school.xml,如下:

复制代码 代码如下:

<?xml version="1.0" encoding="UTF-8"?>
<!--启明培训学校学生信息:
    1、一年级学生
    2、二年级学生 
  -->
  <school name="启明培训学校">
    <grades>
     <grade id="1" name="一年级">
         <classes>
         <class id="101" name="一班">
                 <teachers>
                    <teacher teach="语文"><teacherName><![CDATA[王军]]></teacherName></teacher>
                    <teacher teach="数学"><teacherName><![CDATA[周杰]]></teacherName></teacher>                             
                 </teachers>
                 <students>
                     <student id="10101">
                         <name>亢阳</name>
                          <sex>女</sex>
                     </student>
                     <student id="10102">
                         <name>田镇南</name>
                         <sex>男</sex>
                     </student>
                     <student id="10103">
                         <name>刘嘉</name>
                         <sex>女</sex>
                     </student>
                 </students>
         </class>
        </classes>
     </grade>
        <grade id="2" name="二年级">
         <classes>
         <class id="201" name="二班">
                 <teachers>
                    <teacher teach="语文"><teacherName><![CDATA[胡军]]></teacherName></teacher>
                    <teacher teach="数学"><teacherName><![CDATA[王洁]]></teacherName></teacher>            
                 </teachers>
                 <students >
                     <student id="20101">
                         <name>胡艳</name>
                          <sex>女</sex>
                     </student>
                     <student id="20102">
                         <name>张三</name>
                         <sex>男</sex>
                     </student>
                     <student id="20103">
                         <name>李四</name>
                         <sex>女</sex>
                     </student>
                 </students>
         </class>
        </classes>
     </grade>
</grades>    
  </school> 

2、XMLReader.cs (我用的是控制台应用程序,直接附上全部代码吧) 
复制代码 代码如下:

  using System;
   using System.Collections.Generic;
   using System.Linq;
   using System.Text;
   using System.Xml;
   namespace XMLReader
   {
     class XMLReader
     {
         static void Main(string[] args)
         {
             string xmlFilePath = "school.xml";
             XmlDocument doc = new XmlDocument();
             doc.Load(xmlFilePath);

             //学校  使用xpath表达式选择文档中所有的schoo的子节点
             XmlNodeList schoolNodeList = doc.SelectNodes("/school");
             if (schoolNodeList != null)
             {
                 foreach (XmlNode schoolNode in schoolNodeList)
                 {
                     //通过Attributes获得属性名为name的属性
                     string schoolName = schoolNode.Attributes["name"].Value;
                     Console.WriteLine("学校:" + schoolName);

                     #region 年级
                     //通过SelectSingleNode方法获得当前节点下的grades子节点
                     XmlNode gradesNode = schoolNode.SelectSingleNode("grades");
                     if (gradesNode != null)
                     {
                         //通过ChildNodes属性获得grades的所有一级子节点
                         XmlNodeList gradeNodeList = gradesNode.ChildNodes;
                         if (gradeNodeList != null)
                         {
                             foreach (XmlNode gradeNode in gradeNodeList)
                             {
                                 Console.WriteLine("\t");
                                 Console.WriteLine("年级:" + gradeNode.Attributes["name"].Value + "   ID:" + gradeNode.Attributes["id"].Value);

                                 #region 班级
                                 //通过SelectSingleNode方法获得当前节点下的classes子节点
                                 XmlNode classesNode = gradeNode.SelectSingleNode("classes");
                                 if (classesNode != null)
                                 {
                                     //通过ChildNodes属性获得classes的所有一级子节点
                                     XmlNodeList classNodeList = classesNode.ChildNodes;
                                     if (classNodeList != null)
                                     {
                                         foreach (XmlNode classNode in classNodeList)
                                         {
                              Console.WriteLine("  班级:" + classNode.Attributes["name"].Value + "    ID:" + classNode.Attributes["id"].Value);

                                             #region 老师
                                             XmlNode teachersNode = classNode.SelectSingleNode("teachers");
                                             if (teachersNode != null)
                                             {
                                                 XmlNodeList teacherNodeList = teachersNode.ChildNodes;
                                                 if (teacherNodeList != null)
                                                 {
                                                     foreach (XmlNode teacherNode in teacherNodeList)
                                                     {                                              
                                                         XmlNode teacherNameNode = teacherNode.FirstChild;
                                                         XmlCDataSection cdate = (XmlCDataSection)teacherNameNode.FirstChild;
                                                         if (cdate != null)
                                                         {
                                             Console.WriteLine("   "+teacherNode.Attributes["teach"].Value + "老师:"+cdate.InnerText.Trim());                                                                                                       

                                                         }
                                                     }
                                                 }
                                             }
                                             #endregion  老师

                                                 #region 所有学生
                                                 XmlNode studentsNode = classNode.SelectSingleNode("students");
                                                 if (studentsNode != null)
                                                 {
                                                     XmlNodeList studentNodeList = studentsNode.ChildNodes;
                                                     if (studentNodeList != null)
                                                     {
                                                         foreach (XmlNode studentNode in studentNodeList)
                                                         {
                                                             Console.WriteLine("    学生:" + studentNode.Attributes["id"].Value);

                                                             //获取student的属性值name和文本
                                                             XmlNode stu1 = studentNode.FirstChild;
                                                             XmlElement xe1 = (XmlElement)stu1;
                                                             if (xe1 != null)
                                                             {
                                                                 Console.WriteLine("        姓名:" + xe1.InnerText.Trim());
                                                             }
                                                             //获取student的属性值sex和文本
                                                             XmlNode stu2 = studentNode.LastChild;
                                                             XmlElement xe2 = (XmlElement)stu2;
                                                             if (xe2 != null)
                                                             {
                                                                 Console.WriteLine("        姓别:" + xe2.InnerText.Trim());
                                                             }
                                                         }
                                                     }
                                                 #endregion 所有学生
                                                 }
                                             }
                                         }
                                 #endregion 班级
                                     }
                                 }
                             }
                     #endregion  年级
                             Console.Write("\r\n按随意键跳出");
                             Console.ReadKey();
                         }

                     }
                 }
             }
         }
     }


ok,运行,如图:

相关文章

  • C#中的静态字段double.Epsilon实例详解

    C#中的静态字段double.Epsilon实例详解

    double.Epsilon 是C#中的一个静态字段,表示 double 数据类型的最小可表示的正数值,这篇文章主要介绍了C#中的静态字段double.Epsilon的相关知识,需要的朋友可以参考下
    2024-01-01
  • C#连接MySQL的两个简单代码示例

    C#连接MySQL的两个简单代码示例

    这篇文章主要介绍了C#连接MySQL的简单代码示例,需要的朋友可以参考下
    2017-06-06
  • C#结束进程及子进程

    C#结束进程及子进程

    这篇文章介绍了C#操作结束进程及子进程的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • C#实现加密与解密详解

    C#实现加密与解密详解

    本文详细讲解了C#实现加密与解密详解的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • C# 调用腾讯即时通信 IM的示例

    C# 调用腾讯即时通信 IM的示例

    这篇文章主要介绍了C# 调用腾讯即时通信 IM的示例,帮助大家更好的理解和使用c#,感兴趣的朋友可以了解下
    2020-11-11
  • C#使用log4net结合sqlite数据库实现记录日志

    C#使用log4net结合sqlite数据库实现记录日志

    因为结构化的数据库存储的日志信息,可以写专门的软件读取历史日志信息,通过各种条件筛选,可操作性极大增强,有这方面需求的开发人员可以考虑,本文给大家介绍了C#使用log4net结合sqlite数据库记录日志,需要的朋友可以参考下
    2024-10-10
  • Unity UGUI教程之实现滑页效果

    Unity UGUI教程之实现滑页效果

    使用UGUI提供的ScrollRect和ScrollBar组件实现基本滑动以及自己控制每次移动一页来达到滑页的效果。具体实现思路请参考下本教程
    2016-04-04
  • 使用C#发送带附件的电子邮件的方法的代码示例分析

    使用C#发送带附件的电子邮件的方法的代码示例分析

    这篇文章主要介绍了使用C#发送带附件的电子邮件的方法的代码示例分析,文中还提到了利用163的SMTP服务器发邮件的方法,需要的朋友可以参考下
    2016-02-02
  • C#中enum和string的相互转换

    C#中enum和string的相互转换

    这篇文章主要介绍了C#中enum和string的相互转换的相关资料,需要的朋友可以参考下
    2017-09-09
  • C#基于NPOI生成具有精确列宽行高的Excel文件的方法

    C#基于NPOI生成具有精确列宽行高的Excel文件的方法

    这篇文章主要介绍了C#基于NPOI生成具有精确列宽行高的Excel文件的方法,是C#项目开发中非常实用的技巧,需要的朋友可以参考下
    2014-09-09

最新评论