2008-10-06 13 views
8

讓我們假設我們有這個XML:有沒有辦法在Linq-to-XML查詢中僅使用本地名稱來檢索元素?

<?xml version="1.0" encoding="UTF-8"?> 
<tns:RegistryResponse status="urn:oasis:names:tc:ebxml-regrep:ResponseStatusType:Failure" 
    xmlns:tns="urn:oasis:names:tc:ebxml-regrep:xsd:rs:3.0" 
    xmlns:rim="urn:oasis:names:tc:ebxml-regrep:xsd:rim:3.0"> 
    <tns:RegistryErrorList highestSeverity=""> 
     <tns:RegistryError codeContext="XDSInvalidRequest - DcoumentId is not unique." 
      errorCode="XDSInvalidRequest" 
      severity="urn:oasis:names:tc:ebxml-regrep:ErrorSeverityType:Error"/> 
    </tns:RegistryErrorList> 
</tns:RegistryResponse> 

檢索RegistryErrorList元素,我們可以做

XDocument doc = XDocument.Load(<path to xml file>); 
XNamespace ns = "urn:oasis:names:tc:ebxml-regrep:xsd:rs:3.0"; 
XElement errorList = doc.Root.Elements(ns + "RegistryErrorList").SingleOrDefault(); 

但不喜歡這個

XElement errorList = doc.Root.Elements("RegistryErrorList").SingleOrDefault(); 

有沒有辦法做查詢沒有元素的名稱空間。 Basicly是有什麼conceptially 類同XPath中使用本地名稱()(即// * [本地名稱()= 'RegistryErrorList'])

回答

8
var q = from x in doc.Root.Elements() 
     where x.Name.LocalName=="RegistryErrorList" 
     select x; 

var errorList = q.SingleOrDefault(); 
2

在 「方法」 語法查詢看起來如:

XElement errorList = doc.Root.Elements().Where(o => o.Name.LocalName == "RegistryErrorList").SingleOrDefault(); 
0

以下擴展將從任何級別的XDocument(或任何XContainer)返回匹配元素的集合。

 public static IEnumerable<XElement> GetElements(this XContainer doc, string elementName) 
    { 
     return doc.Descendants().Where(p => p.Name.LocalName == elementName); 
    } 

現在您的代碼應該是這樣的:

var errorList = doc.GetElements("RegistryErrorList").SingleOrDefault(); 
相關問題