asp.net(c#) 中xml具体用法
发布网友
发布时间:2022-04-27 09:20
我来回答
共6个回答
热心网友
时间:2022-04-27 10:50
asp.net创建xml就是通过创建DataTable来创建xml中的树型等
1 DataSet objset=new DataSet();
2 DataTable istable=new DataTable("test");
3 istable.Columns.Add("rate1",typeof(int));
4 istable.Columns.Add("rate2",typeof(int));
5 istable.Columns.Add("rate3",typeof(int));
6 istable.Columns.Add("rate4",typeof(int));
7 objset.Tables.Add(istable);
8
9 DataRow dr=objset.Tables["test"].NewRow();
10 dr[0]=赋值;
11 dr[1]=赋值;
12 dr[2]=赋值;
13 dr[3]=赋值;
14 objset.Tables["money"].Rows.Add(dr);
15
16 objset.WriteXml(Server.MapPath("test.xml"),XmlWriteMode.WriteSchema);
其中就是先创建DataSet和DataTable,其中建立的表为test,再在表中添加子项rate1,2,3,4,再定义新的行,分别添加对应的值,最后这些都已经写进DataSet表中,通过DataSet把xml输入就完成了。要读就只需要把xml的数据读到DataSet中,再通过 DataSet中的表的项来对应读出数据。
而C#中则使用的DOM来实现操作,比如现有一个bookstore.xml文件,内容如下
<?xml version="1.0" encoding="gb2312"?>
<bookstore>
<book genre="fantasy" ISBN="2-3631-4">
<title>Oberon's Legacy</title>
<author>Corets, Eva</author>
<price>5.95</price>
</book>
</bookstore>
下面讲解4种常用的方法
1、往<bookstore>节点中插入一个<book>节点:
XmlDocument xmlDoc=new XmlDocument();
xmlDoc.Load("bookstore.xml");
XmlNode root=xmlDoc.SelectSingleNode("bookstore");//查找<bookstore>
XmlElement xe1=xmlDoc.CreateElement("book");//创建一个<book>节点
xe1.SetAttribute("genre","李赞红");//设置该节点genre属性
xe1.SetAttribute("ISBN","2-3631-4");//设置该节点ISBN属性
XmlElement xesub1=xmlDoc.CreateElement("title");
xesub1.InnerText="CS从入门到精通";//设置文本节点
xe1.AppendChild(xesub1);//添加到<book>节点中
XmlElement xesub2=xmlDoc.CreateElement("author");
xesub2.InnerText="候捷";
xe1.AppendChild(xesub2);
XmlElement xesub3=xmlDoc.CreateElement("price");
xesub3.InnerText="58.3";
xe1.AppendChild(xesub3);
root.AppendChild(xe1);//添加到<bookstore>节点中
xmlDoc.Save("bookstore.xml");
//================
结果为:
<?xml version="1.0" encoding="gb2312"?>
<bookstore>
<book genre="fantasy" ISBN="2-3631-4">
<title>Oberon's Legacy</title>
<author>Corets, Eva</author>
<price>5.95</price>
</book>
<book genre="李赞红" ISBN="2-3631-4">
<title>CS从入门到精通</title>
<author>候捷</author>
<price>58.3</price>
</book>
</bookstore>
2、修改节点:将genre属性值为“李赞红“的节点的genre值改为“update李赞红”,将该节点的子节点<author>的文本修改为“亚胜”。
XmlNodeList nodeList=xmlDoc.SelectSingleNode("bookstore").ChildNodes;//获取bookstore节点的所有子节点
foreach(XmlNode xn in nodeList)//遍历所有子节点
{
XmlElement xe=(XmlElement)xn;//将子节点类型转换为XmlElement类型
if(xe.GetAttribute("genre")=="李赞红")//如果genre属性值为“李赞红”
{
xe.SetAttribute("genre","update李赞红");//则修改该属性为“update李赞红”
XmlNodeList nls=xe.ChildNodes;//继续获取xe子节点的所有子节点
foreach(XmlNode xn1 in nls)//遍历
{
XmlElement xe2=(XmlElement)xn1;//转换类型
if(xe2.Name=="author")//如果找到
{
xe2.InnerText="亚胜";//则修改
break;//找到退出来就可以了
}
}
break;
}
}
xmlDoc.Save("bookstore.xml");//保存。
//=================
最后结果为:
<?xml version="1.0" encoding="gb2312"?>
<bookstore>
<book genre="fantasy" ISBN="2-3631-4">
<title>Oberon's Legacy</title>
<author>Corets, Eva</author>
<price>5.95</price>
</book>
<book genre="update李赞红" ISBN="2-3631-4">
<title>CS从入门到精通</title>
<author>亚胜</author>
<price>58.3</price>
</book>
</bookstore>
3、删除 <book genre="fantasy" ISBN="2-3631-4">节点的genre属性,删除 <book genre="update李赞红" ISBN="2-3631-4">节点。
XmlNodeList xnl=xmlDoc.SelectSingleNode("bookstore").ChildNodes;
foreach(XmlNode xn in xnl)
{
XmlElement xe=(XmlElement)xn;
if(xe.GetAttribute("genre")=="fantasy")
{
xe.RemoveAttribute("genre");//删除genre属性
}
else if(xe.GetAttribute("genre")=="update李赞红")
{
xe.RemoveAll();//删除该节点的全部内容
}
}
xmlDoc.Save("bookstore.xml");
//====================
最后结果为:
<?xml version="1.0" encoding="gb2312"?>
<bookstore>
<book ISBN="2-3631-4">
<title>Oberon's Legacy</title>
<author>Corets, Eva</author>
<price>5.95</price>
</book>
<book>
</book>
</bookstore>
4、显示所有数据。
XmlNode xn=xmlDoc.SelectSingleNode("bookstore");
XmlNodeList xnl=xn.ChildNodes;
foreach(XmlNode xnf in xnl)
{
XmlElement xe=(XmlElement)xnf;
Console.WriteLine(xe.GetAttribute("genre"));//显示属性值
Console.WriteLine(xe.GetAttribute("ISBN"));
XmlNodeList xnf1=xe.ChildNodes;
foreach(XmlNode xn2 in xnf1)
{
Console.WriteLine(xn2.InnerText);//显示子节点点文本
}
}
以上的就是ASP.NET和C#对xml的基本使用方法。下面说一下xml和xsl,从抽象的来说,我个人觉得xml象是数据库,而xsl就象是过滤的。xsl中可以加入html等语法,也可以加入xml的语法等,可以列出需要的数据等。
现有一个xml文件,内容如下
<?xml version="1.0"?>
<?xml-stylesheet type="text/xsl" href="test.xsl"?>
<NewDataSet>
<Table id="1">
<ProctID>1001</ProctID>
<CategoryID>1</CategoryID>
</Table>
<Table id="2">
<ProctID>1002</ProctID>
<CategoryID>2</CategoryID>
</Table>
</NewDataSet>
其中第2句是引用xsl,xsl内容如下
<?xml version="1.0"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">
<xsl:template match="/">
<html>
<body>
<center>
<h2>the notepad</h2>
<table border="1">
<tr>
<td>id</td>
<td>name</td>
</tr>
<xsl:for-each select="NewDataSet/Table">
<tr>
<td><xsl:value-of select="ProctID"/></td>
<td><xsl:value-of select="ProctName"/></td>
</tr>
</xsl:for-each>
</table>
</center>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
中间的for-each就是循环遍历节点,获取指定的select后的内容,下面的value-of就相当于sql中字段名。在使用xsl的时候,还可以查询某一个值,这样xsl就需要如下<xsl:value-of select="/students/student[@id='2']/ProctID"/>
<?xml version="1.0" encoding="gb2312"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">
<xsl:template match="/">
<center> <h1>id号是"2"的厂家的产品ID是:<xsl:value-of select="/NewDataSet/Table[@id='2']/ProctID"/></h1></center>
</xsl:template>
</xsl:stylesheet>
有些如果在Table下还有节点,要显示这个节点下的东西xsl就该如下
<?xml version="1.0"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/TR/WD-xsl">
<xsl:template match="/">
<html>
<body>
<center>
<h2>the notepad</h2>
<table border="1">
<tr>
<td>随便写</td>
</tr>
<xsl:for-each select="NewDataSet/Table/xx/*">
<tr>
<td><xsl:value-of select="."/></td>
</tr>
</xsl:for-each>
</table>
</center>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
热心网友
时间:2022-04-27 12:08
XML与Access,Oracle和SQL Server等数据库不同,数据库提供了更强有力的数据存储和分析能力,例如:数据索引、排序、查找、相关一致性等,XML仅仅是展示数据。事实上XML与其他数据表现形式最大的不同是:他极其简单。这是一个看上去有点琐细的优点,但正是这点使XML与众不同。
热心网友
时间:2022-04-27 13:42
xml只是让你存储一些程序初始化时的参数的 在数据不多的情况下也可用其作为数据岛
热心网友
时间:2022-04-27 15:34
只能是临时的小数据大数据他的性能还是不行的
热心网友
时间:2022-04-27 17:42
请参见
http://www.zu14.cn/net_xml/
asp.net(c#) 中xml具体用法
其中就是先创建DataSet和DataTable,其中建立的表为test,再在表中添加子项rate1,2,3,4,再定义新的行,分别添加对应的值,最后这些都已经写进DataSet表中,通过DataSet把xml输入就完成了。要读就只需要把xml的数据读到DataSet中,再通过 DataSet中的表的项来对应读出数据。 而C#中则使用的DOM来实现操作,比如现有一个...
怎么使用(c#)asp.net打开一个xml文件然后对它进行修改保存。后台工作...
方法一 :使用XML控件 <% @ Page Language="C#"%> 读取XML方法一 <from runat=server> <asp:Xml id="xml1" DocumentSource="grade.xml" runat="server" /> </from> 方法二: 使用DOM技术 <% @ Page Language="C#"%> <% @ Import Namespace="System.Xml"%> <% @ Import Name...
asp.net C# 中用session传递数据的用法
登陆时:session["logininfo"]=txt_userName.Text;用到时:判断session是否存在.if(session["loginifo"]!=null){//调用this.text1.Text=session["loginifo"].ToString();}
c# asp.net 删除XML中的某同类节点
你选到父节点上然后用RemoveAll(),根本不需要循环删除。XmlDocument xmldoc = new XmlDocument();xmldoc.Load("1.xml");XmlNode node = xmldoc.SelectSingleNode("//site[@name='aaa']");node.RemoveAll();
ASP.NET(C#)大学实用教程内容摘要
首先,读者将了解.NET框架的基础概念,包括其架构和重要性,为后续的学习奠定基础。接着,C#语法基础部分将带领你步入C#语言的世界,掌握其核心编程概念和实践技巧。在ASP基础章节,你会学习如何使用C#语言在ASP环境中构建动态网页,理解服务器控件的工作原理和应用。随后,ASP.NET内置对象的章节详细讲解了...
ASP.NET2.0(C#)基础教程 目录
ASP.NET页面概述,文件格式和代码插入ASP.NET 2.0的代码模型和编译机制页面请求和响应机制,以及内置对象如Request和Response实例演示:数据库绑定和XML文档绑定作业:实践页面构建 3.1 使用ASP.NETWeb服务器控件构建Web窗体 Web窗体与ASP.NET控件的区别,CSS应用标准ASP.NET控件如控件、文件上传控件等的...
级联菜单问题(C#,asp.net)
2.第一个DropDownList用服务器端控件,并绑定数据。第二个用客户端Select下拉列表控件,然后写Ajax脚本,再第一个下拉列表发生变化时出发异步请求函数,完成第二个下拉列表的数据绑定(异步请求后台,返回xml格式数据,然后给第二个select控件appendChild一系列的option)。这个方法优点是速度快,兼容性好(我...
asp.net c#的一个初级问题(关于Page_Load的方法的使用)
1,不可以改的,因为它是装载页面时自动执行的.2..3..就不用回答了.可以通过URL参数传递参数到后端.如你上面的后台就能这样取值Request.QueryString["ExtensionName"] 值为 "Theva"
在C#中.cs文件 .xaml文件 .config文件 .asax各是干什么的
.xaml 是微软规范xml语言,wpf和Silverlight,WP8,win8用到(微软主要用于移动领域方面).cs代码文件。.config是配置文件。也是xml语言。微软规范xml语言 .asax是全局应用程序类用的。根据你提供的文件名看。是WEB程序。用Silverlight+WPF做的。.xaml是前台文件 .cs是.xaml后台类。.xmal是继承.cs里类。
.NET怎么修改和添加XML节点的内容?
1.检查所要操作的xml文件是否存在:System.IO.File.Exists(文件路径及名称);2.得到xml文件:(1)在asp.net中可以这样得到:XmlDocument xmlDoc = new XmlDocument();//导入xml文档 xmlDoc.Load( Server.MapPath("xmlTesting.xml"));//导入字符串 //xmlDoc.LoadXml("<bookStore> <book id="01...