程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> xml文件操作,xml文件

xml文件操作,xml文件

編輯:C#入門知識

xml文件操作,xml文件


    public static XmlDocument getDoc(String path)//加載xml文檔
        {
            XmlDocument doc = new XmlDocument();
            doc.Load(path);
            return doc;
        } 
        /// <summary>
        /// 返回找到的節點下標
        /// </summary>
        /// <param name="path">xml文件路徑</param>
        /// <param name="bname">書名</param>
        /// <returns></returns>
        public static int getPosition(String path,string node, String bname)
        {
            int i;
            XmlDocument doc = new XmlDocument();
            doc.Load(path);
            XmlNodeList nodeList = doc.SelectSingleNode(node).ChildNodes;
            for (i = 0; i < nodeList.Count; i++)
            {
                if (nodeList[i].ChildNodes[0].InnerText == bname)
                {
                    return i;
                }
            }
            return -1;

        }

1.遍歷

        /// <summary>
        /// 遍歷數據
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        protected void btnRead_Click(object sender, EventArgs e)
        {

            XmlDocument doc = getDoc("books.xml");//加載xml文檔,books文件存放於
            foreach (XmlElement root in doc.DocumentElement.ChildNodes)//遍歷根的子節點
            {
                Response.Write("<script>document.write('<br/>');</script>");
                Response.Write("<script>document.write('" + root.Name + "');</script>");//節點名root.Name  book
                foreach (XmlElement item in root.ChildNodes)
                {
                    Response.Write("<script>document.write('" + item.Name + "'+':'+'" + item.InnerText + "');</script>");//輸出節點名和文本節點的值
                    Response.Write("<script>document.write('<br/>');</script>");
                }
            }
        }

 

2.查找

        /// <summary>
        /// 查找
        /// </summary>
        /// <param name="path">文件路徑</param>
        /// <param name="node">節點</param>
        /// <param name="bname">查找關鍵字</param>
        /// <returns>XmlNode</returns>
        public static XmlNode Find(string path,string node,string bname)
        {
            XmlDocument doc =  new XmlDocument();
            doc.Load(path);//加載xml文檔
            XmlNodeList nodeList = doc.SelectSingleNode(node).ChildNodes;
            int i = getPosition(path, node, bname);//
            if (i >= 0)
                return nodeList[i];
            else
                return null;
        }

 3.刪除節點

        /// <summary>
        /// 刪除元素、屬性
        /// </summary>
        /// <param name="path">文件</param>
        /// <param name="node">指定節點的父節點</param>
        /// <param name="attribute">為空時刪除節點,否則刪除屬性</param>
        /// <param name="bname"></param>
        public static void Delete(string path,string node,string attribute,string bname)
        {
            XmlDocument doc = new XmlDocument();
            doc.Load(path);
            XmlNode root = doc.SelectSingleNode(node);
            XmlNodeList nodeList = doc.SelectSingleNode(node).ChildNodes;
            int i = getPosition(path, node, bname);//返回指定的節點下標
            if (i >= 0)
            {
                if (attribute.Equals(""))
                {
                    root.RemoveChild(nodeList[i]);
                }
                else
                {
                    XmlElement xn = (XmlElement)nodeList[i];
                    xn.RemoveAttribute(attribute);
                }
            }

            doc.Save(path);

        }

4.添加

        /// <summary>
        /// 添加元素值
        /// </summary>
        /// <param name="path"></param>
        /// <param name="node"></param>
        /// <param name="element"></param>
        /// <param name="value"></param>
        /// <param name="i">插入的下標,如果為負,默認從最後一個節點插入</param>
        /// <returns></returns>
        public static bool Add(string path,string node,string element,string value,int i)
        {
            XmlDocument doc = new XmlDocument();
            doc.Load(path);
            XmlNodeList nodeList = doc.SelectNodes(node);
            XmlNode newNode = doc.SelectSingleNode(node).LastChild;
            if (i < 0 || i > nodeList.Count-1)//如果小於0或者大於節點長度,默認從最後一個節點添加
            {
                XmlElement newElement = doc.CreateElement(element);//創建元素
                newElement.InnerText = value;//賦值
                newNode.AppendChild(newElement);
            }

            else
            {
                XmlElement newElement = doc.CreateElement(element);
                newElement.InnerText = value;
                nodeList[i - 1].AppendChild(newElement);
            }
            doc.Save(path);
            return true;
        }

 


c#,對於對xml文件的操作

文件路徑:... bin\Debug\School.xml
<?xml version="1.0" encoding="utf-8"?>
<Class>
<Student Id="1">
<Age>20</Age>
<Name>AAA</Name>
</Student>
<Student Id="2">
<Age>22</Age>
<Name>BBB</Name>
</Student>
</Class>
---------------------------------------------------
XmlDocument doc = new XmlDocument();
doc.Load("School.xml");
XmlElement root= doc.DocumentElement;
foreach (XmlNode item in root.ChildNodes)
{

if (item.Attributes["Id"].Value == "1")
{

item["Age"].InnerText = "19";
item["Name"].InnerText = "CCC";
}
if (item.Attributes["Id"].Value == "2")
{

item["Age"].InnerText = "23";
item["Name"].InnerText = "18";
}
}
doc.Save("School.xml");
 

XML文件大小問題

SAX處理的優點非常類似於流媒體的優點。分析能夠立即開始,而不是等待所有的數據被處理。而且,由於應用程序只是在讀取數據時檢查數據,因此不需要將數據存儲在內存中。這對於大型文檔來說是個巨大的優點。事實上,應用程序甚至不必解析整個文檔;它可以在某個條件得到滿足時停止解析。一般來說,SAX還比它的替代者DOM快許多。

選擇DOM還是選擇SAX? 對於需要自己編寫代碼來處理XML文檔的開發人員來說, 選擇DOM還是SAX解析模型是一個非常重要的設計決策。 DOM采用建立樹形結構的方式訪問XML文檔,而SAX采用的事件模型。

DOM解析器把XML文檔轉化為一個包含其內容的樹,並可以對樹進行遍歷。用DOM解析模型的優點是編程容易,開發人員只需要調用建樹的指令,然後利用navigation APIs訪問所需的樹節點來完成任務。可以很容易的添加和修改樹中的元素。然而由於使用DOM解析器的時候需要處理整個XML文檔,所以對性能和內存的要求比較高,尤其是遇到很大的XML文件的時候。由於它的遍歷能力,DOM解析器常用於XML文檔需要頻繁的改變的服務中。

SAX解析器采用了基於事件的模型,它在解析XML文檔的時候可以觸發一系列的事件,當發現給定的tag的時候,它可以激活一個回調方法,告訴該方法制定的標簽已經找到。SAX對內存的要求通常會比較低,因為它讓開發人員自己來決定所要處理的tag.特別是當開發人員只需要處理文檔中所包含的部分數據時,SAX這種擴展能力得到了更好的體現。但用SAX解析器的時候編碼工作會比較困難,而且很難同時訪問同一個文檔中的多處不同數據。
 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved