asp.net XML文件操作實現(xiàn)代碼
更新時間:2009年12月24日 01:19:36 作者:
這幾天在項目中用到了XML文件配置存儲一些基本信息,如:參數(shù)、表格等一些信息存儲。由于記錄不是很多,所以用此文件來代替數(shù)據(jù)庫中設計的表結構。
以前也學過一些這方面的知識,好久都沒怎么用了,忘得也差不多,正好現(xiàn)在可以重新鞏固一遍,熟悉一下對XML文件的操作。
XML(Extensible Markup Language)即可擴展標記語言,它與HTML一樣,都是SGML(Standard Generalized Markup Language,標準通用標記語言)。Xml是Internet環(huán)境中跨平臺的,依賴于內容的技術,是當前處理結構化文檔信息的有力工具。
擴展標記語言XML是一種簡單的數(shù)據(jù)存儲語言,使用一系列簡單的標記描述數(shù)據(jù),而這些標記可以用方便的方式建立,雖然XML占用的空間比二進制數(shù)據(jù)要占用更多的空間,但XML極其簡單易于掌握和使用?! ?
XML數(shù)據(jù)類型有:Element,Attribute,Comment,Text
如下一個簡單的XML文件:
代碼
<?xml version="1.0" encoding="UTF-8"?>
<library>
<books id="計算機類">
<book id="10001">
<name>書名1</name>
<publish>出版社1</publish>
<price>價格1</price>
</book>
<book id="10002">
<name>書名2</name>
<publish>出版社2</publish>
<price>價格2</price>
</book>
</books>
<books id="人文類">
<book id="20001">
<name>書名1</name>
<publish>出版社1</publish>
<price>價格1</price>
</book>
<book id="20002">
<name>書名2</name>
<publish>出版社2</publish>
<price>價格2</price>
</book>
</books>
</library>
Element 元素 <book></book>
Attribute 屬性 id="計算機類"
Text 內容 <name>書名2</name>
一般我們要去XML文件中根據(jù)屬性值去查找對應節(jié)點所包含的內容,為了避免嵌套很多節(jié)點的循環(huán),我們可以使用下面的方法,找到所需的節(jié)點。
XmlDocument xdoc = new XmlDocument(); //建立文檔對象
xdoc.Load("book.xml"); //加載xml文件
string Condition = "http://books[@id='計算機類']//book[@id='10001']"; //需要查找節(jié)點的條件
XmlNode node = xdoc.DocumentElement.SelectSingleNode(Condition); //返回符合條件的節(jié)點
foreach (XmlNode xnode1 in node)
{
//該節(jié)點下所有子節(jié)點
XmlNodeList xNodeList2 = node.ChildNodes;
}
查詢條件說明:
1.使用text()來獲取Text節(jié)點
string Condition = "http://books[@id='計算機類']//book[@id='10001']//name//text()";
2.使用[]符號來查詢特定條件的節(jié)點
string Condition = "http://books[@id='計算機類']//book[@id='10001']";
3.使用 | 符號可以獲得多重模式的節(jié)點
string Condition = "http://books[@id='計算機類']//book[@id='10001'] | //books[@id='計算機類']//book[@id='10002']";
4.使用*符號可以返回當前節(jié)點的所有子節(jié)點
string Condition = "http://books[@id='計算機類']//*//name";
XML數(shù)據(jù)的編輯:
1.增加一個元素的屬性(Attribute)節(jié)點
XmlNode xNodeAtt = new XmlNode();
xNodeAtt = xDoc.CreateAttribute("id",book);
xNodeAtt.InnerXml = "10003";
objNode.Attributes.Append(xNodeAtt);
2.刪除一個元素的屬性
objNode.Attributes.Remove(xAtt);
3.增加一個子元素(Element)
XmlNode xNodeAtt = new XmlNode();
xNodeAtt = xDoc.CreateElement("book","書");
xNodeAtt.InnerXml = "10003";
objNode.Attributes.Append(xNodeAtt);
4.刪除一個子元素
objNode.RemoveChild(nodeChild);
5.替換一個子元素
objNode.ReplaceChild(newChild,oldChile);
來自:http://zhf.cnblogs.com/
XML(Extensible Markup Language)即可擴展標記語言,它與HTML一樣,都是SGML(Standard Generalized Markup Language,標準通用標記語言)。Xml是Internet環(huán)境中跨平臺的,依賴于內容的技術,是當前處理結構化文檔信息的有力工具。
擴展標記語言XML是一種簡單的數(shù)據(jù)存儲語言,使用一系列簡單的標記描述數(shù)據(jù),而這些標記可以用方便的方式建立,雖然XML占用的空間比二進制數(shù)據(jù)要占用更多的空間,但XML極其簡單易于掌握和使用?! ?
XML數(shù)據(jù)類型有:Element,Attribute,Comment,Text
如下一個簡單的XML文件:
代碼
復制代碼 代碼如下:
<?xml version="1.0" encoding="UTF-8"?>
<library>
<books id="計算機類">
<book id="10001">
<name>書名1</name>
<publish>出版社1</publish>
<price>價格1</price>
</book>
<book id="10002">
<name>書名2</name>
<publish>出版社2</publish>
<price>價格2</price>
</book>
</books>
<books id="人文類">
<book id="20001">
<name>書名1</name>
<publish>出版社1</publish>
<price>價格1</price>
</book>
<book id="20002">
<name>書名2</name>
<publish>出版社2</publish>
<price>價格2</price>
</book>
</books>
</library>
Element 元素 <book></book>
Attribute 屬性 id="計算機類"
Text 內容 <name>書名2</name>
一般我們要去XML文件中根據(jù)屬性值去查找對應節(jié)點所包含的內容,為了避免嵌套很多節(jié)點的循環(huán),我們可以使用下面的方法,找到所需的節(jié)點。
XmlDocument xdoc = new XmlDocument(); //建立文檔對象
xdoc.Load("book.xml"); //加載xml文件
string Condition = "http://books[@id='計算機類']//book[@id='10001']"; //需要查找節(jié)點的條件
XmlNode node = xdoc.DocumentElement.SelectSingleNode(Condition); //返回符合條件的節(jié)點
foreach (XmlNode xnode1 in node)
{
//該節(jié)點下所有子節(jié)點
XmlNodeList xNodeList2 = node.ChildNodes;
}
查詢條件說明:
1.使用text()來獲取Text節(jié)點
string Condition = "http://books[@id='計算機類']//book[@id='10001']//name//text()";
2.使用[]符號來查詢特定條件的節(jié)點
string Condition = "http://books[@id='計算機類']//book[@id='10001']";
3.使用 | 符號可以獲得多重模式的節(jié)點
string Condition = "http://books[@id='計算機類']//book[@id='10001'] | //books[@id='計算機類']//book[@id='10002']";
4.使用*符號可以返回當前節(jié)點的所有子節(jié)點
string Condition = "http://books[@id='計算機類']//*//name";
XML數(shù)據(jù)的編輯:
1.增加一個元素的屬性(Attribute)節(jié)點
XmlNode xNodeAtt = new XmlNode();
xNodeAtt = xDoc.CreateAttribute("id",book);
xNodeAtt.InnerXml = "10003";
objNode.Attributes.Append(xNodeAtt);
2.刪除一個元素的屬性
objNode.Attributes.Remove(xAtt);
3.增加一個子元素(Element)
XmlNode xNodeAtt = new XmlNode();
xNodeAtt = xDoc.CreateElement("book","書");
xNodeAtt.InnerXml = "10003";
objNode.Attributes.Append(xNodeAtt);
4.刪除一個子元素
objNode.RemoveChild(nodeChild);
5.替換一個子元素
objNode.ReplaceChild(newChild,oldChile);
來自:http://zhf.cnblogs.com/
相關文章
WPF實現(xiàn)ScrollViewer滾動到指定控件處
這篇文章主要為大家詳細介紹了WPF實現(xiàn)ScrollViewer滾動到指定控件處,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06
看到本質而不是現(xiàn)象--解決ASP.NET CS0016的問題
看到本質而不是現(xiàn)象--解決ASP.NET CS0016的問題...2007-01-01
輕量級ORM框架Dapper應用之實現(xiàn)CURD操作
這篇文章介紹了使用Dapper實現(xiàn)CURD操作的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-03-03
asp.net用url重寫URLReWriter實現(xiàn)任意二級域名 新
最近有個朋友要做url重寫的東西,我?guī)退伺?回頭看當年自己寫的那個文章,當時以為自己寫的很容易理解.但現(xiàn)在再看卻覺得寫的不好.而今天百度了一下urlrewriter發(fā)現(xiàn)我這個文章竟然排第二.為了方便更多朋友,我再寫點東西補充下.2009-11-11

