C# XML解析方式實例解析 (帶命名空間的)


 

http://www.csharpwin.com/csharpspace/3968r4687.shtml

 

 C# XML解析通過XPath的方式的步驟:

    1、需要先加載文檔,然后再讀取想要的節點值。

    ◆xml文檔

    protected XmlDocument doc = null;

    ◆xml文檔的根元素(節點)

    protected XmlElement root = null;

    ◆xml文檔的名空間管理器

    protected XmlNamespaceManager nsmgr = null;

    2、接下來就是加載文檔了

  1. protected void LoadXmlFile(FileInfo xmlFile)
  2. {
  3. if (xmlFile == null || !xmlFile.Exists)
  4. {
  5. throw new FileNotFoundException(
  6. string.Format("要解析的文件不存在{0}。",
  7. xmlFile.FullName));
  8. }
  9. //加載文件
  10. this.doc = new XmlDocument();
  11. doc.Load(xmlFile.FullName);
  12. //准備讀取文件
  13. root = doc.DocumentElement;
  14. string nameSpace = root.NamespaceURI;
  15. nsmgr = new XmlNamespaceManager(doc.NameTable);
  16. nsmgr.AddNamespace("ns", nameSpace);
  17. }

    ◆C# XML解析通過XPath的方式要注意。

    a、這兩行是取得xml文檔的名空間

  1. root = doc.DocumentElement;
  2. string nameSpace = root.NamespaceURI;

    b、這兩行是建立xml文檔的名空間管理器

  1. nsmgr = new XmlNamespaceManager(doc.NameTable);
  2. nsmgr.AddNamespace("ns", nameSpace);

    如果你的xml文檔有名空間,則這部分的代碼是必不可少的。

    3、接下來就是讀取文檔節點的值了

    這里兩個傳入參數prefixPath是節點的上級節點路徑,xRelativePath是要讀取的節點名稱。

    另外,變量XmlFileInfo是要加載的xml文件。

  1. protected string GetNodeValue(
  2. string prefixPath, string xRelativePath)
  3. {
  4. if (doc == null)
  5. {
  6. LoadXmlFile(XmlFileInfo);
  7. }
  8. string xPath = string.Empty;
  9. if (!string.IsNullOrEmpty(xRelativePath))
  10. {
  11. if (!string.IsNullOrEmpty(prefixPath))
  12. {
  13. xPath = prefixPath + xRelativePath;
  14. }
  15. else
  16. {
  17. xPath = xRelativePath;
  18. }
  19. }
  20. xPath = xPath.Replace("/", "/ns:");
  21. XmlNode node = root.SelectSingleNode(xPath, nsmgr);
  22. if (node == null)
  23. {
  24. return null;
  25. }
  26. return node.InnerXml;
  27. }

    可能有的朋友要問,為什么要設置兩個參數prefixPath和xRelativePath呢,其實這個沒有多大的關系,我只是為了自己覺得方便,你也可以在方法外確定了這個XPath,在方法中只設置一個傳入參數,效果是一樣的。

    ◆注意這一行:

  1. xPath = xPath.Replace("/", "/ns:");

    如果你的xml文檔帶名空間,則這行是比不可少的,否則會出現找不到節點,無法解析的情況。

    關於XPath的一些問題:

    對於這樣一個xml文檔,要查找第一個節點下的學生的Name時(ID=01),其XPath應該是"/ns:Root/ns:Students/ns:Student[1]/ns:Name"。xml對於重復的節點名稱,是按照順序1,2,3...的方式遍歷的,也就是說如果要找第N個Student節點的下的節點之,那么應使用Student[N]的標識方式。

  1. ﹤?xml version="1.0" encoding="UTF-8" ?﹥
  2. ﹤Root xmlns="urn:ClassNameSpace"
  3. ﹤Class﹥
  4. ﹤ClassID﹥1234﹤/ClassID﹥
  5. ﹤/Class﹥
  6. ﹤Students﹥
  7. ﹤Student﹥
  8. ﹤ID﹥01﹤/ID﹥﹤Name﹥Name01﹤/Name﹥
  9. ﹤/Student﹥
  10. ﹤Student﹥
  11. ﹤ID﹥02﹤/ID﹥﹤Name﹥Name02﹤/Name﹥
  12. ﹤/Student﹥
  13. ﹤/Students﹥
  14. ﹤/Root﹥

    當然,這里也可以獲取節點屬性的值,查找滿足特定值的節點等等,這些和上面獲取節點值的過程是類似的。

    C# XML解析通過XPath的方式的實現就向你介紹到這里,希望對你了解和學習C# XML解析有所幫助。

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM