asp.net读取xml文件相关内容
2009-04-20 14:35
615 查看
Xml基本概念
声明这是一个xml文档
2. 用xml标识创建的内容
如:<UserID>luoluoluo</UserID>
Tag(标签):是用来定义元素的,必须成对出现,如有<UserID>,比如有</UserID>
Attribute(属性):如<UserID kkk=”12”>luoluoluo</UserID>,其中kkk为属性,完全可以把属性转化为子元素
2. Declaration(声明):文档的第一行必须使用xml声明,告诉浏览器这是一个xml文档
3. Parent Element(父元素) Child Element(子元素):父元素指包含其他元素的元素,被包含的称为子元素
4. DTD(文件类型定义):定义xml元素,属性,以及元素属性之间关系。通过DTD可以检测xml文档的结构是否正确。
5. Schema(规划):是数据规则的描述,完成两件事
1)定义元素数据类型和元素之间的关系
2)定义元素所包含的内容类型
6. Document Tree(文档树)
文档树是文档元素愤激结构的形象表示。一个文档结构树包含亘呀,他是最顶级的元素
2. 注意大小写
3. 属性必须加上引号
4. 标签必须关闭
标签成对,且关闭
5. 元素名称中不能带有空格,“:”,xml保留字
6. 元素名不能以“_”开头
DataSet与Xml
DataSet具有操作xml的功能,将xml文档读入DataSet的方法是ReadXml,将DataSet写入xml的方法是WriteXml,他们带有一个参数,可以是TextReader,Stream,也可以是String。
string strXmlPath = Server.MapPath("TestXml.xml");
ds.ReadXml(strXmlPath);
DataGrid1.DataSource = ds.Tables[0].DefaultView;
DataGrid1.DataBind();
ds.WriteXml(strXmlPath);
具体例子
TestXml.xml
<?xml version="1.0" standalone="yes"?>
<NewDataSet xmlns="http://tempuri.org/TestXml.xsd">
<User>
<UserID>luoluoluo</UserID>
<UserPwd>luoluoPwd</UserPwd>
<UserLevel>1</UserLevel>
</User>
</NewDataSet>
功能:从xml中把数据读入DataSet,然后绑定到DataGrid1中,然后修改,并添加数据,再写入到xml中,然后再从xml中把数据读如DataSet,然后绑定到DataGrid2
DataSet ds = new DataSet();
string strXmlPath = Server.MapPath("TestXml.xml");
ds.ReadXml(strXmlPath);
DataGrid1.DataSource = ds.Tables[0].DefaultView;
DataGrid1.DataBind();
DataTable dt = ds.Tables[0];
//修改
DataRow dr = dt.Rows[0];
dr["UserID"] = "luoluoluo";
dr["UserPwd"] = "luoluoPwd";
DataRow drAdd = dt.NewRow();
drAdd["UserID"] = "luoAdd";
drAdd["UserPwd"] = "luoAddPwd";
drAdd["UserLevel"] = 2;
dt.Rows.Add(drAdd);
ds.AcceptChanges();
//写入xml
ds.WriteXml(strXmlPath);
ds.Clear();
ds.ReadXml(strXmlPath);
//绑定到dataGrid2
DataGrid2.DataSource = ds.Tables[0].DefaultView;
DataGrid2.DataBind();
使用ReadXml读出xml文档时,需要注意一下几点:
1. 文档树不超过三层,否则读出有问题
2. 根元素不使用属性,否则读出有问题
3. 根元素超过一个,则多余的根元素和子元素无效,即只读出第一个根元素
其他:
xDoc.Load(Server.MapPath("TestXml.xml"));
XmlNodeReader xReader = new XmlNodeReader(xDoc);
string strID="",strPwd="",strLevel="";
while (xReader.Read())
{
if (xReader.NodeType==XmlNodeType.Element)
{
switch (xReader.Name)
{
case "UserID":
xReader.Read();
strID = xReader.Value;
break;
case "UserPwd":
xReader.Read();
strPwd = xReader.Value;
break;
case "UserLevel":
xReader.Read();
strLevel = xReader.Value;
break;
default:
break;
}
}
}
xDoc.Load(Server.MapPath("TestXml.xml"));
XmlNodeList xNodeList = xDoc.GetElementsByTagName("UserID");
Label3.Text = xNodeList[0].InnerXml;
对于XmlDocument,XmlNodeReader,XmlNodeList等也没什么概念,再多多读文档再补充
一.Xml文档包括两部分内容
1. 一个xml文档声明声明这是一个xml文档
2. 用xml标识创建的内容
二.Xml中的基本概念
1. Element(元素):构成xml文档的最小单位,即xml文档表示的单个数据,如:<UserID>luoluoluo</UserID>
Tag(标签):是用来定义元素的,必须成对出现,如有<UserID>,比如有</UserID>
Attribute(属性):如<UserID kkk=”12”>luoluoluo</UserID>,其中kkk为属性,完全可以把属性转化为子元素
2. Declaration(声明):文档的第一行必须使用xml声明,告诉浏览器这是一个xml文档
3. Parent Element(父元素) Child Element(子元素):父元素指包含其他元素的元素,被包含的称为子元素
4. DTD(文件类型定义):定义xml元素,属性,以及元素属性之间关系。通过DTD可以检测xml文档的结构是否正确。
5. Schema(规划):是数据规则的描述,完成两件事
1)定义元素数据类型和元素之间的关系
2)定义元素所包含的内容类型
6. Document Tree(文档树)
文档树是文档元素愤激结构的形象表示。一个文档结构树包含亘呀,他是最顶级的元素
三.Xml语法
1. Xml文档中必须有声明2. 注意大小写
3. 属性必须加上引号
4. 标签必须关闭
标签成对,且关闭
5. 元素名称中不能带有空格,“:”,xml保留字
6. 元素名不能以“_”开头
DataSet与Xml
DataSet具有操作xml的功能,将xml文档读入DataSet的方法是ReadXml,将DataSet写入xml的方法是WriteXml,他们带有一个参数,可以是TextReader,Stream,也可以是String。
1. xml读入DataSet
DataSet ds = new DataSet();string strXmlPath = Server.MapPath("TestXml.xml");
ds.ReadXml(strXmlPath);
DataGrid1.DataSource = ds.Tables[0].DefaultView;
DataGrid1.DataBind();
2.DataSet写入Xml
string strXmlPath = Server.MapPath("TestXml.xml");ds.WriteXml(strXmlPath);
具体例子
TestXml.xml
<?xml version="1.0" standalone="yes"?>
<NewDataSet xmlns="http://tempuri.org/TestXml.xsd">
<User>
<UserID>luoluoluo</UserID>
<UserPwd>luoluoPwd</UserPwd>
<UserLevel>1</UserLevel>
</User>
</NewDataSet>
功能:从xml中把数据读入DataSet,然后绑定到DataGrid1中,然后修改,并添加数据,再写入到xml中,然后再从xml中把数据读如DataSet,然后绑定到DataGrid2
DataSet ds = new DataSet();
string strXmlPath = Server.MapPath("TestXml.xml");
ds.ReadXml(strXmlPath);
DataGrid1.DataSource = ds.Tables[0].DefaultView;
DataGrid1.DataBind();
DataTable dt = ds.Tables[0];
//修改
DataRow dr = dt.Rows[0];
dr["UserID"] = "luoluoluo";
dr["UserPwd"] = "luoluoPwd";
DataRow drAdd = dt.NewRow();
drAdd["UserID"] = "luoAdd";
drAdd["UserPwd"] = "luoAddPwd";
drAdd["UserLevel"] = 2;
dt.Rows.Add(drAdd);
ds.AcceptChanges();
//写入xml
ds.WriteXml(strXmlPath);
ds.Clear();
ds.ReadXml(strXmlPath);
//绑定到dataGrid2
DataGrid2.DataSource = ds.Tables[0].DefaultView;
DataGrid2.DataBind();
使用ReadXml读出xml文档时,需要注意一下几点:
1. 文档树不超过三层,否则读出有问题
2. 根元素不使用属性,否则读出有问题
3. 根元素超过一个,则多余的根元素和子元素无效,即只读出第一个根元素
其他:
读取xml文档指定结点
1.使用XmlNodeReader
XmlDocument xDoc = new XmlDocument();xDoc.Load(Server.MapPath("TestXml.xml"));
XmlNodeReader xReader = new XmlNodeReader(xDoc);
string strID="",strPwd="",strLevel="";
while (xReader.Read())
{
if (xReader.NodeType==XmlNodeType.Element)
{
switch (xReader.Name)
{
case "UserID":
xReader.Read();
strID = xReader.Value;
break;
case "UserPwd":
xReader.Read();
strPwd = xReader.Value;
break;
case "UserLevel":
xReader.Read();
strLevel = xReader.Value;
break;
default:
break;
}
}
}
2. 使用XmlNodeList
XmlDocument xDoc = new XmlDocument();xDoc.Load(Server.MapPath("TestXml.xml"));
XmlNodeList xNodeList = xDoc.GetElementsByTagName("UserID");
Label3.Text = xNodeList[0].InnerXml;
对于XmlDocument,XmlNodeReader,XmlNodeList等也没什么概念,再多多读文档再补充
相关文章推荐
- asp.net 读取xml文件里面的内容,绑定到dropdownlist中
- Asp.Net 读取xml文件中Key的值,并且过滤掉注释内容代码
- asp.net 上传XML,txt 直接读取文件内容
- ASP.NET通过http/https的POST方式,发送和接受XML文件内容
- ASP.NET读取XML文件4种方法(转载)
- ASP.NET读取XML文件4种方法
- 今天在ASP.NET上在写一个读取EXCEL文件内容的功能,但是IE8貌似把文件路径给屏蔽了,在IE6下面读取正常!有啥好办法?
- VB.NET 从XML文件中读取内容到JSON
- 在asp.net中读取XML文件信息的4种方法
- HttpContext是干什么的; asp.net 获取网站路径;DataSet读取xml文件;updatepanel 控件的局部刷新 always和condition
- ASP.NET中读取XML文件信息的4种方法与示例代码
- ASP.NET读取XML文件中常用的四种方法知识讲解
- ASP.NET FileUpload不经保存,直接读取上传文件的内容
- 分析ASP.NET读取XML文件4种方法
- ASP.NET中读取XML文件信息的4种方法与示例代码
- asp.net中读取XML文件信息的4种方法
- 分析ASP.NET读取XML文件4种方法
- asp.net c# 如何读取XML文件里的CDATA里的HTML