开发者社区> 科技小先锋> 正文

读取xml文件的方式(29)

简介:
+关注继续查看
xml(可扩展标记语言)在网络开发中经常用到,也是各种数据交换的标准,在web程序中应用越来越广 泛,可以通过xml来实现配置管理、传递对象和数据等。在asp.net中读取一个xml文件主要有以下几种方式:利用xml控件,使用Dom技术。使用 xmltextreader类,或者利用dataset对象。首先添加命名空间:
using System.Xml.Linq; 
using System.Xml;
  1. 使用xml控件读取xml文件
默认主页源代码:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="xml._Default" %>

<!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 runat="server">
<title>读取xml文件</title>
</head>
<body>
<h2>利用控件读取xml文件</h2>
<form id="form1" runat="server" method ="post">
<div>
<asp:Xml ID="Xml1" runat="server" DocumentSource="~/XMLFile1.xml"></asp:Xml>
</div>
</form>
</body>
</html>

效果图:
神舟龙
2.使用Dom技术读取xml文件
xmldocument类来读取xml文件,将整个待读取的xml文件在内存中通过xml解析器生成Dom。然后通过xml控件的document 属性赋值,或通过节点的相对位置来选择节点并显示或处理数据。
给xml文件控件的document属性赋值
public partial class _Default : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
XmlDocument xd=new XmlDocument();
string xmlpath=Server.MapPath("~/XMLFile1.xml");
xd.Load(@xmlpath);
this.Xml1.Document = xd;

xmldocument类可以通过节点的childnodes属性来获取所有子节点,而每个子节点又可以通过xmlnode类来表示。
代码:
 protected void Page_Load(object sender, EventArgs e)
{
XmlNode node;
XmlDocument xd=new XmlDocument();//定义一个xmldocument对象
string xmlpath=Server.MapPath("~/XMLFile1.xml");//加载xml文件
xd.Load(@xmlpath);
XmlElement tree = xd.DocumentElement;
for (int i = 0; i < tree.ChildNodes.Count; i++)//对根子节点的所有子节点进行循环
{
node=tree.ChildNodes[i];
if (node.HasChildNodes)//判断是否还有子节点
{
string content = "";
for (int j = 0; j < node.ChildNodes.Count; j++)
{
XmlNode childnode = node.ChildNodes[j];
content += childnode.Name + childnode.InnerText + "&nbsp;&nbsp;";
}
}
Content+="</br>";
Response.Write(Content);//输出
}
}

3.通过xmltextreader类来读取xml文档,现在设计页面拖放一个table控件
实例代码:
 protected void Page_Load(object sender, EventArgs e)
{

string xmlpath=Server.MapPath("~/XMLFile1.xml");//定义xml对象
XmlTextReader xtr=new XmlTextReader (@xmlpath );//声明一个xmltextreader对象xtr
TableRow tr=new TableRow ();
while (xtr.Read())//调用xml文件的读方法
{
if (xtr.NodeType == XmlNodeType.Text)//判断当前是否为文本
{
TableCell tc = new TableCell();
tc.Text = xtr.Value;
tr.Cells.Add(tc);
}
if (xtr.NodeType == XmlNodeType.EndElement && xtr.Name == "student")//判断当前是否为student节点结束标记,若是,则将前面构建的数据行添加表table1.,并初始化对象tr
{
this.Table1.Rows.Add(tr);
tr = new TableRow();
}

}
xtr.Close();
}

效果图:
效果

4.在读取xml文档时,可以借助dataset作为中间桥梁,将xml文档读入到数据集中,然后通过数据表操作方法对xml包含的数据进行处理, 下列程序是读取xml文档学号>002的信息
代码:
protected void Page_Load(object sender, EventArgs e)
{

string xmlpath=Server.MapPath("~/XMLFile1.xml");//定义xml对象
DataSet ds = new DataSet();//创建数据集对象
ds.ReadXml(@xmlpath);//利用readxml方法读取xml文件
DataView dv=ds.Tables[0].DefaultView;//定义数据视图对象
dv.RowFilter = "学号>=002";//根据条件筛选
this.GridView1.DataSource = dv;//在空间gridview中显示
this.GridView1.DataBind();
}

效果图:
表

本文转自shenzhoulong  51CTO博客,原文链接:http://blog.51cto.com/shenzhoulong/333199,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
hutool读取xml文件
hutool读取xml文件
141 0
java积累——dom4j读取xml文件
java积累——dom4j读取xml文件
107 0
【前端】白天/黑夜主题切换:JS读取XML预设主题实现黑白主题切换
【前端】白天/黑夜主题切换:JS读取XML预设主题实现黑白主题切换
43 0
python读取linux上的xml文件
python远程读取linxu服务器上的xml文件
33 0
XML转CSV读取对应所有数据(tkinter工具)
代码段:处理xml标签和标签名的数据读取
27 0
【目标检测】一文干翻xml文件的读取
【目标检测】一文干翻xml文件的读取
103 0
Sring源码解析(一)Spring是怎么读取配置Xml文件的
1#Spring读取配置文件 ##Document 在XmlBeanDefinitionReader.doLoadBeanDefinitions(InputSource inputSource, Resource resource)方法中将Xml文件转换成Document对象;Document doc = doLoadDocument(inputSource, resource);
69 0
【Unity3D日常】使用Unity3D读取Json、XML、Excel文件
在日常开发中会遇到很多读取文件的操作,最常见的类型还是Json、txt、XML、Excel文件,那么今天就分享一下如何读取这几类文件
212 0
Spring源码(二-3)-XML文件的读取-factory-method的使用
Spring 可以通过 factory-method 实例化对象。factory-method方式是 Spirng 实例对象的方式之一。
709 0
Spring源码(二-1)-XML文件的读取-bean标签
上篇博文看到的四个标签中, bean 的解析最为复杂和重要。
552 0
+关注
科技小先锋
文章
问答
视频
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载