在.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=""/>
<item name="天下网生活论坛" url="http://life.netskycn.com" id=""/>
<item name="csdn" url="http://www.csdn.net" id=""/>
<item name="我的博客" url="http://blog.csdn.net/zhoufoxcn" id=""/>
<item name="百度" url="http://www.baidu.com" id=""/>
<item name="Google" url="http://www.google.cn" id=""/>
<item name="微软" url="http://www.microsoft.com" id=""/>
</Menu>
<Menu title="娱乐网址">
<item name="奇虎" url="http://www.qihoo.com" id=""/>
<item name="网易" url="http://www.163.com" id=""/>
<item name="天涯" url="http://www.tianya.cn" id=""/>
</Menu>
<Menu title="安全网址">
<item name="" url="http://www.safe360.com" id=""/>
<item name="瑞星" url="http://www.rising.com.cn" id=""/>
</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 = ; i < xmlReader.AttributeCount; i++)
{
xmlReader.MoveToAttribute(i);
Response.Write("属性:" + xmlReader.Name + "=" + xmlReader.Value+"&nbsp;");
}
break;
case XmlNodeType.Attribute:
for (int i = ; 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 = ; 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==

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

  1. 【C#-读取XML文件】XMLReader读取XML文档

    使用   XmlReader.Create("文件路径")   加载xml文件 XmlReader使用流的方式来读取. //使用XMLReader读取XML数据 XmlReader ...

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

    刚到新单位,学习他们的源代码,代码里读写系统配置文件的XML代码比较老套,直接写在一个系统配置类里,没有进行类的拆分,造成类很庞大,同时,操作XML的读写操作都是使用SetAttribute和node ...

  3. C#读取XML文件的方法

    先写一个xml文件: <?xml version="1.0" encoding="utf-8" ?> <bookste> <!-- ...

  4. 在C#中创建和读取XML文件

    1.创建简单的XML文件 为了便于测试,我们首先创建控制台应用程序,项目命名为CreateXml,Program.cs代码如下: 这样会在C盘根目录下创建data2.xml文件,文件内容为 using ...

  5. Java获取路径方法&相对路径读取xml文件方法

    (1).request.getRealPath("/");//不推荐使用获取工程的根路径 (2).request.getRealPath(request.getRequestURI ...

  6. python读取xml文件

    关于python读取xml文章很多,但大多文章都是贴一个xml文件,然后再贴个处理文件的代码.这样并不利于初学者的学习,希望这篇文章可以更通俗易懂的教如何使用python 来读取xml 文件. 什么是 ...

  7. 读取xml文件转成List<T>对象的两种方法(附源码)

    读取xml文件转成List<T>对象的两种方法(附源码) 读取xml文件,是项目中经常要用到的,所以就总结一下,最近项目中用到的读取xml文件并且转成List<T>对象的方法, ...

  8. C#中经常使用的几种读取XML文件的方法

    XML文件是一种经常使用的文件格式,比如WinForm里面的app.config以及Web程序中的web.config文件,还有很多重要的场所都有它的身影.Xml是Internet环境中跨平台的,依赖 ...

  9. python专题-读取xml文件

    关于python读取xml文章很多,但大多文章都是贴一个xml文件,然后再贴个处理文件的代码.这样并不利于初学者的学习,希望这篇文章可以更通俗易懂的教如何使用python 来读取xml 文件. 什么是 ...

随机推荐

  1. C# DES 加密解密

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.S ...

  2. 使用FindControl("id")查找控件 返回值都是Null的问题

    做了一个通过字符串ID查找页面控件并且给页面控件赋值的功能,过程中遇到了this.FindControl("id")返回值都是Null的问题,记录一下解决办法. 问题的原因是我所要 ...

  3. 转:C#整数三种强制类型转换int、Convert.ToInt32()、int.Parse()的区别

    1.int适合简单数据类型之间的转换,C#的默认整型是int32(不支持bool型); 2.int.Parse(string sParameter)是个构造函数,参数类型只支持string类型; 3. ...

  4. 生成简历经验总结(解析HTML字符串)

    在生成简历的过程中,我的做法是首先设计一个word的简历模板,设置好书签,从数据库中读取数据,调用aspose进行填充.一般的数据项包括图片文件都没有问题. 问题出在了HTML字符串上.因为简历中有几 ...

  5. RecyclerView实现ViewPager效果

    RecyclerView实现ViewPager效果,以及横向的ListView效果.效果图如下: Github: https://github.com/hpu-spring87/recyclervie ...

  6. Dom4j使用Xpath语法读取xml节点

    我们可以使用Xpath的语法来轻易的读取xml的某个节点[类似于jQuery的选择器]: 使用Xpath语法需要添加新的jaxen-1.1-beta-7.rar 这个jar包 dom4j完整jar包我 ...

  7. Entity Framework 利用 Database.SqlQuery<T> 执行存储过程,并返回Output参数值

    做个记录: var pCount = this._dataProvider.GetParameter(); pCount.ParameterName = "totalCount"; ...

  8. 回文数猜想(hd1282)

    回文数猜想 Problem Description 一个正整数,如果从左向右读(称之为正序数)和从右向左读(称之为倒序数)是一样的,这样的数就叫回文数.任取一个正整数,如果不是回文数,将该数与他的倒序 ...

  9. ALM11客户端安装办法

    使用HP公司的QC11(ALM11.0)做项目缺陷管理,发现QC只支持IE7,IE8.其实可以通过安装ALM自已提供的浏览器就行了. 第一步:关闭UAC(用户账户控制) 第二步:打开ie,将ie-in ...

  10. MySQL5.7新特性笔记

    001.用户验证方式上的变化 MySQL5.7已经不要支持mysql_old_password验证插件,也不再支持old_password函数,也就说old_passwords也就不能被设置成1了.