标题:向大家请教:如何在XML中追加记录
只看楼主
沐海思潮
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2006-6-7
 问题点数:0 回复次数:3 
向大家请教:如何在XML中追加记录

比如说,我有一个XML是这个样子的
<channel>
<item>
<link></link>
<title></title>
<GUID></GUID>
</item>
<item>

<link></link>
<title></title>
<GUID></GUID>
</item>
</channel>



我如何向里面追加一个item以及item 中的各种属性

请高手指点一下
帮我示范几行C#代码,不胜感激

[此贴子已经被作者于2006-6-9 15:50:22编辑过]

搜索更多相关主题的帖子: XML item title GUID link 
2006-06-09 15:49
沐海思潮
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2006-6-7
得分:0 

有没有高人来指点我一下呢……


2006-06-12 21:39
沐海思潮
Rank: 1
等 级:新手上路
帖 子:16
专家分:0
注 册:2006-6-7
得分:0 

怎么还没有一个人来帮个忙呢?


2006-06-14 20:35
liubaoen
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:104
专家分:117
注 册:2006-6-12
得分:0 

第二章:往现有XML文件添加记录
另外C#又提供了一个更方便的方式让我们操作XML,那就是DATASET
其实我们可以这样认为,DATASET其实就是多个XML文件,通过DATASET一些内置的方法和属性操作XML,非常灵活
我们继续假设,现有一个XML文件,如下:
<?xml version="1.0" encoding="gb2312"?>
<users>
<user id="1">
<userName>outrace</userName>
<userPass>mypass</userPass>
</user>
<user id="2">
<userName>trace</userName>
<userPass>mypass</userPass>
</user>
</users>
则通过下面的代码进行写入操作
<% @ Import Namespace="System.IO" %>
<% @ Import Namespace="System.Xml" %>
<% @ Import Namespace="System.Data" %>
<Script Language="C#" Runat="Server" Debug="true">
public void Page_Load(Object src,EventArgs e)
{
/*
* 版 权 : copyright by SEM IT DEPARTMENT
* 版 本 : version 0.0.1
* 文 件 : InsertXml_2.aspx
* 用 途 : 使用DATASET的方式往XML里添加数据
* 作 者 : 欧阳云天 @2005-4-9
* 邮 箱 : outrace@soueast-motor.com
* 修 改 :
*/

String fileName;
fileName = "users_2.xml";
DataSet myDs = new DataSet();

try
{
FileStream fin ;
fin = new FileStream(Server.MapPath("./files/"+fileName), FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
myDs.ReadXml(fin);
fin.Close();
}
catch (Exception ex)
{
Response.Write(ex.Message);
}

//绑定修改前的XML
PreData.DataSource = myDs.Tables[0].DefaultView; //指定数据源
PreData.DataBind(); //绑定数据

//当DS当中增加新行
//在这里我们可以看到,其实原XML数据里面的属性,我们一样可以直接使用DataRow[]数组来得到,而不仅仅是节点
DataRow newRow = myDs.Tables[0].NewRow();
newRow["id"] = "3";
newRow["userName"] = "new user";
newRow["userPass"] = "new passwd";
myDs.Tables[0].Rows.Add(newRow);

//将myDs的改变写入XML
try
{
FileStream dataOut;
dataOut = new FileStream(Server.MapPath("./files/"+fileName), FileMode.Open, FileAccess.Write, FileShare.ReadWrite);
myDs.WriteXml(dataOut, XmlWriteMode.WriteSchema);
dataOut.Close();
}
catch (Exception ex)
{
Response.Write(ex.Message);
}

//绑定修改后的XML
NextData.DataSource = myDs.Tables[0].DefaultView; //指定数据源
NextData.DataBind(); //绑定数据

myDs.Dispose();
}
</script>

<html>

<head>
<title>插入一条数据</title>
</head>

<body>
<form runat ="server">
<table width="100%">
<tr>
<td>写入前</td>
<td>写入后</td>
</tr>
<tr>
<td valign="top"><asp:DataGrid id="PreData" runat ="server"/></td>
<td valign="top"><asp:DataGrid id="NextData" runat ="server"/></td>
</tr>
</table>
</form>
</body>

</html>
通过上面的操作,我们将得到的XML结果如下:
<users>
<xs:schema id="users" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
<xs:element name="users" msdata:IsDataSet="true" msdata:Locale="zh-CN">
<xs:complexType>
<xs:choice maxOccurs="unbounded">
<xs:element name="user">
<xs:complexType>
<xs:sequence>
<xs:element name="userName" type="xs:string" minOccurs="0" msdata:Ordinal="0" />
<xs:element name="userPass" type="xs:string" minOccurs="0" msdata:Ordinal="1" />
</xs:sequence>
<xs:attribute name="id" type="xs:string" />
</xs:complexType>
</xs:element>
</xs:choice>
</xs:complexType>
</xs:element>
</xs:schema>
<user id="1">
<userName>outrace</userName>
<userPass>mypass</userPass>
</user>
<user id="2">
<userName>trace</userName>
<userPass>mypass</userPass>
</user>
<user id="3">
<userName>new user</userName>
<userPass>new passwd</userPass>
</user>
</users>

2006-06-14 22:26



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-70896-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.019356 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved