亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

asp.net XML文件操作實(shí)現(xiàn)代碼

 更新時(shí)間:2009年12月24日 01:19:36   作者:  
這幾天在項(xiàng)目中用到了XML文件配置存儲(chǔ)一些基本信息,如:參數(shù)、表格等一些信息存儲(chǔ)。由于記錄不是很多,所以用此文件來(lái)代替數(shù)據(jù)庫(kù)中設(shè)計(jì)的表結(jié)構(gòu)。
以前也學(xué)過(guò)一些這方面的知識(shí),好久都沒(méi)怎么用了,忘得也差不多,正好現(xiàn)在可以重新鞏固一遍,熟悉一下對(duì)XML文件的操作。
  XML(Extensible Markup Language)即可擴(kuò)展標(biāo)記語(yǔ)言,它與HTML一樣,都是SGML(Standard Generalized Markup Language,標(biāo)準(zhǔn)通用標(biāo)記語(yǔ)言)。Xml是Internet環(huán)境中跨平臺(tái)的,依賴于內(nèi)容的技術(shù),是當(dāng)前處理結(jié)構(gòu)化文檔信息的有力工具。
  擴(kuò)展標(biāo)記語(yǔ)言XML是一種簡(jiǎn)單的數(shù)據(jù)存儲(chǔ)語(yǔ)言,使用一系列簡(jiǎn)單的標(biāo)記描述數(shù)據(jù),而這些標(biāo)記可以用方便的方式建立,雖然XML占用的空間比二進(jìn)制數(shù)據(jù)要占用更多的空間,但XML極其簡(jiǎn)單易于掌握和使用?! ?
  XML數(shù)據(jù)類(lèi)型有:Element,Attribute,Comment,Text
  如下一個(gè)簡(jiǎn)單的XML文件:
代碼
復(fù)制代碼 代碼如下:

<?xml version="1.0" encoding="UTF-8"?>
<library>
<books id="計(jì)算機(jī)類(lèi)">
<book id="10001">
<name>書(shū)名1</name>
<publish>出版社1</publish>
<price>價(jià)格1</price>
</book>
<book id="10002">
<name>書(shū)名2</name>
<publish>出版社2</publish>
<price>價(jià)格2</price>
</book>
</books>
<books id="人文類(lèi)">
<book id="20001">
<name>書(shū)名1</name>
<publish>出版社1</publish>
<price>價(jià)格1</price>
</book>
<book id="20002">
<name>書(shū)名2</name>
<publish>出版社2</publish>
<price>價(jià)格2</price>
</book>
</books>
</library>

  Element 元素 <book></book>
  Attribute 屬性 id="計(jì)算機(jī)類(lèi)"
  Text 內(nèi)容 <name>書(shū)名2</name>

  一般我們要去XML文件中根據(jù)屬性值去查找對(duì)應(yīng)節(jié)點(diǎn)所包含的內(nèi)容,為了避免嵌套很多節(jié)點(diǎn)的循環(huán),我們可以使用下面的方法,找到所需的節(jié)點(diǎn)。
  XmlDocument xdoc = new XmlDocument(); //建立文檔對(duì)象
  xdoc.Load("book.xml"); //加載xml文件
  string Condition = "http://books[@id='計(jì)算機(jī)類(lèi)']//book[@id='10001']"; //需要查找節(jié)點(diǎn)的條件
  XmlNode node = xdoc.DocumentElement.SelectSingleNode(Condition); //返回符合條件的節(jié)點(diǎn)
  foreach (XmlNode xnode1 in node)
{
//該節(jié)點(diǎn)下所有子節(jié)點(diǎn)
XmlNodeList xNodeList2 = node.ChildNodes;
  }

  查詢條件說(shuō)明:
  1.使用text()來(lái)獲取Text節(jié)點(diǎn)
  string Condition = "http://books[@id='計(jì)算機(jī)類(lèi)']//book[@id='10001']//name//text()";
  2.使用[]符號(hào)來(lái)查詢特定條件的節(jié)點(diǎn)
  string Condition = "http://books[@id='計(jì)算機(jī)類(lèi)']//book[@id='10001']";
  3.使用 | 符號(hào)可以獲得多重模式的節(jié)點(diǎn)
  string Condition = "http://books[@id='計(jì)算機(jī)類(lèi)']//book[@id='10001'] | //books[@id='計(jì)算機(jī)類(lèi)']//book[@id='10002']";
  4.使用*符號(hào)可以返回當(dāng)前節(jié)點(diǎn)的所有子節(jié)點(diǎn)
  string Condition = "http://books[@id='計(jì)算機(jī)類(lèi)']//*//name";
 
XML數(shù)據(jù)的編輯:
1.增加一個(gè)元素的屬性(Attribute)節(jié)點(diǎn)
   XmlNode xNodeAtt = new XmlNode();
 xNodeAtt = xDoc.CreateAttribute("id",book);
 xNodeAtt.InnerXml = "10003";
 objNode.Attributes.Append(xNodeAtt);
2.刪除一個(gè)元素的屬性
    objNode.Attributes.Remove(xAtt);
3.增加一個(gè)子元素(Element)
    XmlNode xNodeAtt = new XmlNode();
  xNodeAtt = xDoc.CreateElement("book","書(shū)");
 xNodeAtt.InnerXml = "10003";
 objNode.Attributes.Append(xNodeAtt);
4.刪除一個(gè)子元素
    objNode.RemoveChild(nodeChild);
5.替換一個(gè)子元素
    objNode.ReplaceChild(newChild,oldChile);
來(lái)自:http://zhf.cnblogs.com/

相關(guān)文章

最新評(píng)論