使用XmlReader读取xml文件之二

在.net开发中经常需要读写xml形式的文件(app.config和web.config分别是WinForm和WebForm中使用到的 xml文件的一个特列,并且微软提供了通用的方法,在此就不赘述了), .net类库提供了多种读写xml文件的方式,每一种方式都有其优点和 缺点,因而有其实用性。

下面列出微软.net类库提供的读写xml文件个类及其特点:

类名称 优点 缺点
XmlReader 快速、高效、可扩展 只读,只向前,需要人工验证
XmlDocument 可往返、可读写、支持XPath筛选 比XmlReader慢
XPathNavigator 可往返,支持XPath和XSLT 只读
XPathDocument 比XmlDocument,优化支持XPath和XSLT 比XmlReader慢

本文提到的XmlReader也是微软类库中的一个类,它的特点是快速高效,并且可扩展,缺点是只读。

下面举例说明XmlReader的用法:
(一)用到的xml文件:meu.xml

<?xml version="1.0" encoding="utf-8" ?>
<Menus>
  <Menu title="常用网址">
    <item name="天下网" url="http://www.netskycn.com" id="1"/>
    <item name="天下网生活论坛" url="http://life.netskycn.com" id="2"/>
    <item name="csdn" url="http://www.csdn.net" id="3"/>
    <item name="我的博客" url="http://blog.csdn.net/zhoufoxcn" id="4"/>
    <item name="百度" url="http://www.baidu.com" id="5"/>
    <item name="Google" url="http://www.google.cn" id="6"/>
    <item name="微软" url="http://www.microsoft.com" id="7"/>
  </Menu>
  <Menu title="娱乐网址">
    <item name="奇虎" url="http://www.qihoo.com" id="12"/>
    <item name="网易" url="http://www.163.com" id="13"/>
    <item name="天涯" url="http://www.tianya.cn" id="14"/>
  </Menu>
  <Menu title="安全网址">
    <item name="360" url="http://www.safe360.com" id="15"/>
    <item name="瑞星" url="http://www.rising.com.cn" id="16"/>
  </Menu>
</Menus>

(二)读取并显示:ReadXml.aspx

<%@ Page Language="C#" ContentType="text/html" ResponseEncoding="gb2312" %>
<%@ Import Namespace="System.Xml" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>XMLReader实例</title>
</head>
<body>
<script runat="server">
//首发地址:http://blog.csdn.net/zhoufoxcn/archive/2007/12/23/1961624.aspx
protected void Page_Load(Object Src, EventArgs E)
{
  if (!IsPostBack)
  {
      XmlReader xmlReader = XmlReader.Create(Server.MapPath("Menu.xml"));
            while (xmlReader.Read())
            {
                Response.Write("<li>节点类型:" + xmlReader.NodeType + "==<br>");
                switch (xmlReader.NodeType)
                {
                    case XmlNodeType.XmlDeclaration:
                        for (int i = 0; i < xmlReader.AttributeCount; i++)
                        {
                            xmlReader.MoveToAttribute(i);
                            Response.Write("属性:" + xmlReader.Name + "=" + xmlReader.Value+"&nbsp;");
                        }
                        break;
                    case XmlNodeType.Attribute:
                        for (int i = 0; i < xmlReader.AttributeCount; i++)
                        {
                            xmlReader.MoveToAttribute(i);
                            Response.Write("属性:" + xmlReader.Name + "=" + xmlReader.Value+"&nbsp;");
                        }
                        break;
                    case XmlNodeType.CDATA:
                        Response.Write("CDATA:" + xmlReader.Value+"&nbsp;");
                        break;
                    case XmlNodeType.Element:
                        Response.Write("节点名称:" + xmlReader.LocalName+"<br>");
                        for (int i = 0; i < xmlReader.AttributeCount; i++)
                        {
                            xmlReader.MoveToAttribute(i);
                            Response.Write("属性:" + xmlReader.Name + "=" + xmlReader.Value+"&nbsp;");
                        }
                        break;
                    case XmlNodeType.Comment:
                        Response.Write("Comment:" + xmlReader.Value);
                        break;
                    case XmlNodeType.Whitespace:
                        Response.Write("Whitespace:" + "&nbsp;");
                        break;
                    case XmlNodeType.ProcessingInstruction:
                        Response.Write("ProcessingInstruction:" + xmlReader.Value);
                        break;
                    case XmlNodeType.Text:
                        Response.Write("Text:" + xmlReader.Value);
                        break;
                }
            }
            xmlReader.Close();
  }
}
</script>
</body>
</html>

特别说明的是:menu.xml和ReadXml.aspx文件放在同一个文件夹下,如果实际情况与此不符,请根据实际情况更改。

以下是输出结果:

  • 节点类型:XmlDeclaration==
    属性:version=1.0 属性:encoding=utf-8
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:Menus
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:Menu
    属性:title=常用网址
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=天下网 属性:url=http://www.netskycn.com 属性:id=1
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=天下网生活论坛 属性:url=http://life.netskycn.com 属性:id=2
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=csdn 属性:url=http://www.csdn.net 属性:id=3
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=我的博客 属性:url=http://blog.csdn.net/zhoufoxcn 属性:id=4
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=百度 属性:url=http://www.baidu.com 属性:id=5
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=Google 属性:url=http://www.google.cn 属性:id=6
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=微软 属性:url=http://www.microsoft.com 属性:id=7
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:EndElement==
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:Menu
    属性:title=娱乐网址
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=奇虎 属性:url=http://www.qihoo.com 属性:id=12
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=网易 属性:url=http://www.163.com 属性:id=13
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=天涯 属性:url=http://www.tianya.cn 属性:id=14
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:EndElement==
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:Menu
    属性:title=安全网址
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=360 属性:url=http://www.safe360.com 属性:id=15
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:Element==
    节点名称:item
    属性:name=瑞星 属性:url=http://www.rising.com.cn 属性:id=16
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:EndElement==
  • 节点类型:Whitespace==
    Whitespace:
  • 节点类型:EndElement==
时间: 2024-11-03 21:05:51

使用XmlReader读取xml文件之二的相关文章

C#读取XML文件的基类实现

刚到新单位,学习他们的源代码,代码里读写系统配置文件的XML代码比较老套,直接写在一个系统配置类里,没有进行类的拆分,造成类很庞大,同时,操作XML的读写操作都是使用SetAttribute和node.Attribute(name)方法,因此,想到结合之前所做的XML操作,完成了一个能够读取XML文件的基类,便于以后的使用. PS:即使再老套的代码,目前也不敢进行优化,一是水平不行,二是不敢. 使用静态扩展类,扩展了几个经常使用的类型,能够方便数据的读写. 操作XML的类,可以直接继承BaseL

Excel开发学习笔记:读取xml文件及csv文件

读取xml文件 有好多种读取xml的方式,xmlDOM比较常见,我使用了另外一种,它以数据流的方式打开文件并读取内容 Imports System.Xml  Dim group As New List(Of String)  Using reader As XmlReader = XmlReader.Create(OpenFileDialog2.FileName)      While reader.ReadToFollowing("group")          reader.Mo

Java使用相对路径读取xml文件

java使用相对路径读取xml文件 博客分类: java javaXMLJavaWeb 一.xml文件一般的存放位置有三个: 1.放在WEB-INF下: 2.xml文件放在/WEB-INF/classes目录下或classpath的jar包中: 3.放在与解析它的java类同一个包中,不一定是classpath: 二.相对应的两种使用相对路径的读取方法: 方法一:(未验证) 将xml文件放在WEB-INF目录下,然后 程序代码: InputStream is=getServletContext(

C#中常用的几种读取XML文件的方法

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

C# 读取xml文件忽略xml文件的注释

默认情况下,读取xml文件是不忽略注释的,这样读取带注释的节点会造成异常,那么怎么屏蔽掉这些注释呢? 方案如下: XmlDocument doc = new XmlDocument(); XmlReaderSettings settings = new XmlReaderSettings(); settings.IgnoreComments = true; //xmlFilePath:xml文件路径 XmlReader reader = XmlReader.Create(xmlFilePath,

android开发步步为营之24:milliondollars游戏技术要点代码生成控件和读取xml文件

Milliondollars智力问答游戏,主要的技术要点(一).读取题库数据xml文件(二).如何动态的生成题目和选项.这里做个总结,供以后参考. (一).读取题库数据xml文件 将assets/topics.xml文件读取 topics.xml格式: <?xml version="1.0" encoding="UTF-8"?> <book> <question topic="<全唐诗>是哪个时期的人编辑的?&qu

Asp.Net 读取xml文件中Key的值,并且过滤掉注释内容代码

/// <summary> /// 读取配置文件keys /// </summary> /// <returns></returns> public string _GetKeys() { string filename = Server.MapPath("/") + @"web.config"; XmlDocument xmldoc = new XmlDocument(); XmlReaderSettings set

python专题-读取xml文件

关于python读取xml文章很多,但大多文章都是贴一个xml文件,然后再贴个处理文件的代码.这样并不利于初学者的学习,希望这篇文章可以更通俗易懂的教如何使用python 来读取xml 文件. 什么是xml? xml即可扩展标记语言,它可以用来标记数据.定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言. abc.xml <?xml version="1.0" encoding="utf-8"?> <catalog> <max

使用Pull解析器生成XML文件和读取xml文件

有些时候,我们需要生成一个XML文件,生成XML文件的方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中:或者使用DOM API生成XML文件,或者也可以使用pull解析器生成XML文件,这里推荐大家使用Pull解析器. 一.布局界面 [html] view plaincopyprint? <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"