ASP.NET XmlDocument类详解
xmldocument类是.net框架的doc解析器。xmldocument将xml视为树状结构,它装载xml文档,并在内存中构建该文档的树状结构。下面来看下xmldocument提供了哪些功能。
一、属性:
attributes 获取一个 xmlattributecollection,它包含该节点的属性。 (继承自 xmlnode。)
baseuri 获取当前节点的基 uri。 (重写 xmlnode..::.baseuri。)
childnodes 获取节点的所有子节点。 (继承自 xmlnode。)
documentelement 获取文档的根 xmlelement。
documenttype 获取包含 doctype 声明的节点。
firstchild 获取节点的第一个子级。 (继承自 xmlnode。)
haschildnodes 获取一个值,该值指示节点是否有任何子节点。 (继承自 xmlnode。)
implementation 获取当前文档的 xmlimplementation 对象。
innertext 获取或设置节点及其所有子节点的串联值。 (继承自 xmlnode。)
innerxml 获取或设置表示当前节点子级的标记。 (重写 xmlnode..::.innerxml。)
isreadonly 获取一个值,该值指示当前节点是否是只读的。 (重写 xmlnode..::.isreadonly。)
item 已重载。
lastchild 获取节点的最后一个子级。 (继承自 xmlnode。)
localname 获取节点的本地名称。 (重写 xmlnode..::.localname。)
name 获取节点的限定名。 (重写 xmlnode..::.name。)
namespaceuri 获取该节点的命名空间 uri。 (继承自 xmlnode。)
nametable 获取与此实现关联的 xmlnametable。
nextsibling 获取紧接在该节点之后的节点。 (继承自 xmlnode。)
nodetype 获取当前节点的类型。 (重写 xmlnode..::.nodetype。)
outerxml 获取表示此节点及其所有子节点的标记。 (继承自 xmlnode。)
ownerdocument 获取当前节点所属的 xmldocument。 (重写 xmlnode..::.ownerdocument。)
parentnode 已重载。
prefix 获取或设置该节点的命名空间前缀。 (继承自 xmlnode。)
preservewhitespace 获取或设置一个值,该值指示是否在元素内容中保留空白。
previoussibling 获取紧接在该节点之前的节点。 (继承自 xmlnode。)
schemainfo 返回节点的后架构验证信息集 (psvi)。 (重写 xmlnode..::.schemainfo。)
schemas 获取或设置与此 xmldocument 关联的 xmlschemaset 对象。
value 获取或设置节点的值。 (继承自 xmlnode。)
xmlresolver 设置 xmlresolver 以用于解析外部资源。
二、方法
appendchild 将指定的节点添加到该节点的子节点列表的末尾。 (继承自 xmlnode。)
clone 创建此节点的一个副本。 (继承自 xmlnode。)
clonenode 创建此节点的一个副本。 (重写 xmlnode..::.clonenode(boolean)。)
createattribute 已重载。 创建具有指定名称的 xmlattribute。
createcdatasection 创建包含指定数据的 xmlcdatasection。
createcomment 创建包含指定数据的 xmlcomment。
createdefaultattribute 创建具有指定前缀、本地名称和命名空间 uri 的默认属性。
createdocumentfragment 创建 xmldocumentfragment。
createdocumenttype 返回新的 xmldocumenttype 对象。
createelement 已重载。 创建 xmlelement。
createentityreference 创建具有指定名称的 xmlentityreference。
createnavigator 已重载。 创建一个用于导航此文档的新 xpathnavigator 对象。
createnode 已重载。 创建 xmlnode。
createprocessinginstruction 创建一个具有指定名称和数据的 xmlprocessinginstruction。
createsignificantwhitespace 创建一个 xmlsignificantwhitespace 节点。
createtextnode 创建具有指定文本的 xmltext。
createwhitespace 创建一个 xmlwhitespace 节点。
createxmldeclaration 创建一个具有指定值的 xmldeclaration 节点。
getelementbyid 获取具有指定 id 的 xmlelement。
getelementsbytagname 已重载。 返回一个 xmlnodelist,它包含与指定名称匹配的所有子代元素的列表。
getenumerator 提供对 xmlnode 中节点上“for each”样式迭代的支持。 (继承自 xmlnode。)
gethashcode 用作特定类型的哈希函数。 (继承自 object。)
getnamespaceofprefix 查找当前节点范围内离给定的前缀最近的 xmlns 声明,并返回声明中的命名空间 uri。 (继承自 xmlnode。)
getprefixofnamespace 查找当前节点范围内离给定的命名空间 uri 最近的 xmlns 声明,并返回声明中定义的前缀。 (继承自 xmlnode。)
importnode 将节点从另一个文档导入到当前文档。
insertafter 将指定的节点紧接着插入指定的引用节点之后。 (继承自 xmlnode。)
insertbefore 将指定的节点紧接着插入指定的引用节点之前。 (继承自 xmlnode。)
load 已重载。 从 stream、url、textreader 或 xmlreader 加载指定的 xml 数据。
loadxml 从指定的字符串加载 xml 文档。
normalize 将此 xmlnode 下子树完全深度中的所有 xmltext 节点都转换成“正常”形式,在这种形式中只有标记(即标记、注释、处理指令、 cdata 节和实体引用)分隔 xmltext 节点,也就是说,没有相邻的 xmltext 节点。 (继承自 xmlnode。)
prependchild 将指定的节点添加到该节点的子节点列表的开头。 (继承自 xmlnode。)
readnode 根据 xmlreader 中的信息创建一个 xmlnode 对象。读取器必须定位在节点或属性上。
removeall 移除当前节点的所有子节点和/或属性。 (继承自 xmlnode。)
removechild 移除指定的子节点。 (继承自 xmlnode。)
replacechild 用 newchild 节点替换子节点 oldchild。 (继承自 xmlnode。)
save 已重载。 将 xml 文档保存到指定的位置。
selectnodes 已重载。
selectsinglenode 已重载。
supports 测试 dom 实现是否实现特定的功能。 (继承自 xmlnode。)
validate 已重载。 验证 xmldocument 是不是 schemas 属性中包含的 xml 架构定义语言 (xsd) 架构。
writecontentto 将 xmldocument 节点的所有子级保存到指定的 xmlwriter 中。 (重写 xmlnode..::.writecontentto(xmlwriter)。)
writeto 将 xmldocument 节点保存到指定的 xmlwriter。 (重写 xmlnode..::.writeto(xmlwriter)。)
三、事件
nodechanged 当属于该文档的节点的 value 已被更改时发生。
nodechanging 当属于该文档的节点的 value 将被更改时发生。
nodeinserted 当属于该文档的节点已被插入另一个节点时发生。
nodeinserting 当属于该文档的节点将被插入另一个节点时发生。
noderemoved 当属于该文档的节点已被从其父级移除时发生。
noderemoving 当属于该文档的节点将被从文档中移除时发生。
助记属性:
previoussibling 上一个兄弟节点
nextsibling 下一个兄弟节点
firstchild 第一个子节点
lastchild 最后一个子节点
childnodes 子节点集合
parentnode 父节点
代码示例:
xml文档:
<?xml version="1.0" encoding="utf-8" ?>
<article>
<author age="30">张三</author>
<length>12000</length>
<price>42</price>
</article>
代码:
static void main(string[] args)
{
xmldocument doc = new xmldocument();
doc.load(@"c:\users\administrator\desktop\consoleapplication1\consoleapplication1\test.xml");
//先获取一个唯一的article节点,再获取其下的第一个子节点 然后再获取该节点下的属性集合
xmlattributecollection xc = doc.selectsinglenode("article").firstchild.attributes;
string age = xc[0].value; //不过是一个定制的集合罢了,还是集合那套东西 //string age = xc["age"].value; 支持两种索引访问
console.writeline(age); //输出30
string baseuri = doc.selectsinglenode("article").firstchild.baseuri;
console.writeline(baseuri); //输出 file:///c:\users\administrator\desktop\consoleapplication1\consoleapplication1\test.xml
xmlnodelist listnode = doc.selectsinglenode("article").childnodes; //获取article节点下的所有节点列表
for (int i = 0; i < listnode.count;i++ ) //xmlnodelist不支持foreach遍历,只能用for
{
console.write(listnode[i].name + " : " + listnode[i].innertext); //输出 author:张三 length:12000 price:30 name获取的是限定名,也就是标记名称
}
xmlelement xe = doc.documentelement; //获取根节点
console.writeline(xe.name); //输出 article
//xmldocumenttype xdt = doc.documenttype; //获取包含 doctype 声明的节点。应该是由dtd限定的节点。
//console.write(xdt.name); //此处报 未将对象引用设置到对象的实例,因为找不到有doctype声明的元素
console.writeline(doc.haschildnodes); //输出 true 当前document是否包含子节点。
//xmlimplementation xi = doc.implementation; //不懂怎么用
//xi.tostring();
console.writeline(doc.innertext); //获取当前文档的内容 输出 张三 12000 30
console.writeline(doc.innerxml); //输出 整个xml文件的字符串内容
console.writeline(doc.isreadonly); //获取当前文档是否是只读的。输出 false
xmlnode node = doc.lastchild;
console.writeline(node.innertext); //输出 张三 12000 30 因为最后一个节点是article节点,输出article节点的所有内容
console.writeline(doc.localname); //输出 #document
console.writeline(doc.selectsinglenode("article").name); //输出article
console.writeline(doc.selectsinglenode("article").firstchild.nextsibling.name); //length author的下一个兄弟节点 是length
xmlnodetype xnt = doc.selectsinglenode("article").nodetype;
console.writeline(xnt); //输出element,表明该节点是元素节点
string str = doc.selectsinglenode("article").outerxml; //此节点及其所有自己点标记,输出article节点的所有内容 <article>省略...</article>
console.writeline(str);
xmldocument x = new xmldocument();
x.loadxml(str);
console.writeline(doc.selectsinglenode("article").ownerdocument); //获取该节点所属的xmldocument
xmlnode xn = doc.selectsinglenode("article").lastchild.parentnode; //parentnode获取直接父节点。
console.writeline(xn.name); //输出 article
console.writeline(doc.preservewhitespace); //是否保留空白 输出false
xmlnode xn1 = doc.selectsinglenode("article").lastchild.previoussibling;
console.writeline(xn1.name); //输出length 的确是最后一个节点的前一个节点。
console.readkey();
}
为了更加好的展示一些属性,现在将xml换成这样:
<?xml version="1.0" encoding="utf-8" ?>
<h:article xmlns:h = "http://www.xxx.com/">
<!--默认命名空间-->
<h:author age="30">张三</h:author>
<h:length>12000</h:length>
<h:price>42</h:price>
</h:article>
代码如下:
static void main(string[] args)
{
xmldocument doc = new xmldocument();
doc.load(@"c:\users\administrator\desktop\consoleapplication1\consoleapplication1\test.xml");
xmlnamespacemanager xnm = new xmlnamespacemanager(doc.nametable);
xnm.addnamespace("h", "http://www.xxx.com/");
xmlnode article = doc.selectsinglenode("h:article", xnm);
string namespace1 = article.innertext;
console.writeline(namespace1); //输出 张三 12000 30
console.writeline(article.prefix); //输出 h 获取当前节点的前缀
console.writeline(article.namespaceuri); //输出 http://www.xxx.com/123 获取当前节点所在的命名空间
console.writeline(article.firstchild.name + "---" + article.firstchild.value + "---" + article.firstchild.localname);
//以上一行代码输出 h:author------author
//schemainfo 返回节点的后架构验证信息集 (psvi)。//value 获取或设置节点的值。 (继承自 xmlnode。)
//xmlresolver 设置 xmlresolver 以用于解析外部资源。
console.readkey();
}
再来一个展示一下schemas这个常用的属性
static void main(string[] args)
{
xmldocument doc = new xmldocument(); //创建文档
doc.schemas.add(null, @"c:\users\administrator\desktop\consoleapplication1\consoleapplication1\person.xsd"); //添加一个架构对象到本xmldocument
doc.load(@"c:\users\administrator\desktop\consoleapplication1\consoleapplication1\person.xml"); //加载xml文件
console.writeline(doc.schemas.count); //输出1 就是第二行添加的那个
console.writeline(doc.schemainfo.membertype);
//xmlresolver 设置 xmlresolver 以用于解析外部资源。
console.readkey();
}
下面来试下xmldocument的方法
test.xml的代码如下:
<?xml version="1.0" encoding="utf-8" ?>
<bookstore>
<book>
<id>1</id>
<title lang="属性1">三国演义</title>
<author>罗贯中</author>
<year>2005</year>
<price id='a1"'>38.5</price>
</book>
<book>
<id>2</id>
<title lang="属性2">西游记</title>
<author>吴承恩</author>
<year>2004</year>
<price>37.5</price>
</book>
</bookstore>
主程序代码如下:
static void main(string[] args)
{
xmldocument doc = new xmldocument(); //创建文档
doc.load(@"c:\users\administrator\desktop\consoleapplication1\consoleapplication1\test.xml"); //加载xml文件
xmlnode node1 = doc.createnode(xmlnodetype.element, "pagecount", null);
node1.innertext = "222";
doc.selectsinglenode("/bookstore").appendchild(node1); //执行之后 <pagecount>222</pagecount>元素被添加到</bookstore>前面
doc.save(@"d:\123.xml");
xmlnode node2 = doc.selectsinglenode("/bookstore/book[1]/title[1]").clone(); //克隆一个节点出来
console.writeline(node2.innertext); //输出三国演义
xmlnode node3 = doc.selectsinglenode("/bookstore/book[1]/title[1]").clonenode(true); //参数决定是否克隆子节点数(如果false,文本节点也不克隆)
console.writeline(node3.innertext); //输出三国演义
xmlattribute attr = doc.createattribute("age"); //创建一个age属性
attr.value = "23";
doc.selectsinglenode("/bookstore/book[1]/author[1]").attributes.append(attr); //执行之后第一个作者变为 <author age="23">罗贯中</author>
doc.save(@"d:\123.xml");
xmlcdatasection cdata = doc.createcdatasection("我&你");
doc.selectsinglenode("/bookstore/book[1]/author[1]").appendchild(cdata); //执行之后author变为<author age="23">罗贯中<![cdata[我&你]]></author>
doc.save(@"d:\123.xml");
xmlcomment com = doc.createcomment("2013-2-27 22:37:25");
doc.selectsinglenode("/bookstore/book[1]/title[1]").appendchild(com); //执行之后title变为<title lang="属性1">三国演义<!--2013-2-27 22:37:25--></title>
doc.save(@"d:\123.xml");
xmldocument doc1 = new xmldocument();
xmldocumentfragment xdf = doc1.createdocumentfragment(); //一个xml片段,这个类敢情好用
xdf.innerxml = "<item>widget</item>";
doc1.appendchild(xdf);
console.writeline(doc1.outerxml); //输出<item>widget</item>
//createdefaultattribute 创建具有指定前缀、本地名称和命名空间 uri 的默认属性。
//createdocumenttype 返回新的 xmldocumenttype 对象。
xmldocument doc2 = new xmldocument();
xmlelement element = doc2.createelement("title"); //创建一个title 如果现在保存是输出<title/> 因为还没有内容
doc2.appendchild(element);
xmlentityreference xer = doc2.createentityreference("h");
doc2.lastchild.appendchild(xer);
console.writeline(doc2.outerxml); //输出</title>&h;</title>
xpathnavigator nav = doc2.createnavigator(); //一个通过光标的导航模型遍历xml文档的数据
xmltext text = doc2.createtextnode("你好啊"); //创建一个文本节点
doc2.selectsinglenode("/title").appendchild(text);
console.writeline(doc2.outerxml); //输出</title>&h;你好啊</title>
xmlwhitespace xws = doc2.createwhitespace(" "); //创建一个空白节点
doc2.selectsinglenode("/title").appendchild(xws);
console.writeline(doc2.outerxml); //输出</title>&h;你好啊 </title>
xmldeclaration xd = doc2.createxmldeclaration("1.0", "utf-8", "yes"); //xml头 xml声明部分
xmlnode root = doc2.selectsinglenode("/title");
doc2.insertbefore(xd, root);
console.writeline(doc2.outerxml); //执行之后 在头部加入了<?xml version="1.0" encoding="utf-8" standalont="yes"?>
xmlsignificantwhitespace xsw = doc2.createsignificantwhitespace(" ");
xmlelement ele = doc2.createelement("white");
ele.innertext = "空白啊空白";
ele.appendchild(xsw);
doc2.selectsinglenode("/title").appendchild(ele);
console.writeline(doc2.outerxml); //还是添加一大堆空白,不知道与createwhitespace有什么区别
xmldocument doc3 = new xmldocument();
string pitext = "type='text/xsl' href='book.xsl'";
xmlprocessinginstruction newpi = doc3.createprocessinginstruction("xml-stylesheet", pitext);
doc3.appendchild(newpi);
console.writeline(doc3.outerxml); //输出 <?xml-stylesheet type="text/xsl" hred="book.xsl"?>
//getelementbyid 获取具有指定 id 的 xmlelement。
//getelementsbytagname 已重载。 返回一个 xmlnodelist,它包含与指定名称匹配的所有子代元素的列表。
//getenumerator 提供对 xmlnode 中节点上“for each”样式迭代的支持。 (继承自 xmlnode。)
//getnamespaceofprefix 查找当前节点范围内离给定的前缀最近的 xmlns 声明,并返回声明中的命名空间 uri。 (继承自 xmlnode。)
//getprefixofnamespace 查找当前节点范围内离给定的命名空间 uri 最近的 xmlns 声明,并返回声明中定义的前缀。 (继承自 xmlnode。)
//importnode 将节点从另一个文档导入到当前文档。
//insertafter 将指定的节点紧接着插入指定的引用节点之后。 (继承自 xmlnode。)
//insertbefore 将指定的节点紧接着插入指定的引用节点之前。 (继承自 xmlnode。)
//loadxml 从指定的字符串加载 xml 文档。
//normalize 将此 xmlnode 下子树完全深度中的所有 xmltext 节点都转换成“正常”形式,在这种形式中只有标记(即标记、注释、处理指令、 cdata 节和实体引用)分隔 xmltext 节点,也就是说,没有相邻的 xmltext 节点。 (继承自 xmlnode。)
//prependchild 将指定的节点添加到该节点的子节点列表的开头。 (继承自 xmlnode。)
//readnode 根据 xmlreader 中的信息创建一个 xmlnode 对象。读取器必须定位在节点或属性上。
//removeall 移除当前节点的所有子节点和/或属性。 (继承自 xmlnode。)
//removechild 移除指定的子节点。 (继承自 xmlnode。)
//replacechild 用 newchild 节点替换子节点 oldchild。 (继承自 xmlnode。)
//supports 测试 dom 实现是否实现特定的功能。 (继承自 xmlnode。)
//validate 已重载。 验证 xmldocument 是不是 schemas 属性中包含的 xml 架构定义语言 (xsd) 架构。
//writecontentto 将 xmldocument 节点的所有子级保存到指定的 xmlwriter 中。 (重写 xmlnode..::.writecontentto(xmlwriter)。)
//writeto 将 xmldocument 节点保存到指定的 xmlwriter。 (重写 xmlnode..::.writeto(xmlwriter)。)
console.readkey();
}
上一篇: 好似是bom问题
下一篇: 如何用PHP调用WebService?