Linq to XML读取XPath(读取所有节点)
问题描述:
这是我的XML文件,包含一个xmlns。我试图读取文件动态的所有节点。Linq to XML读取XPath(读取所有节点)
第一个节点(文档)工作正常,但其他节点没有。
可以帮我解决这个问题。
<?xml version="1.0" encoding="UTF-8"?><Document>
<BkToCstmrAcctRpt xmlns="urn:iso:std:iso:325235:tech:xsd:camt.052.001.03">
<GrpHdr>
<MsgId>NONREF</MsgId>
<CreDtTm>2017-09-27T15:10:01.597560</CreDtTm>
<MsgPgntn>
<PgNb>1</PgNb>
<LastPgInd>true</LastPgInd>
</MsgPgntn>
</GrpHdr>
<Rpt>
<Id>T2S</Id>
<CreDtTm>2017-09-27T15:10:01.597560+02:00</CreDtTm>
<Acct>
<Id>
<Othr>
<Id>24234234234234234234we234</Id>
</Othr>
</Id>
<Ccy>EUR</Ccy>
<Ownr>
<Id>
<OrgId>
</OrgId>
</Id>
</Ownr>
<Svcr>
<FinInstnId>
<BICFI>HJASDESPBESMMXXX</BICFI>
</FinInstnId>
</Svcr>
</Acct>
<Bal>
<Tp>
<CdOrPrtry>
<Prtry>CASH</Prtry>
</CdOrPrtry>
</Tp>
<Amt Ccy="EUR">0.00</Amt>
<CdtDbtInd>CRDT</CdtDbtInd>
<Dt>
<Dt>2017-09-27</Dt>
</Dt>
</Bal>
<Bal>
<Tp>
<CdOrPrtry>
<Prtry>PCAS</Prtry>
</CdOrPrtry>
</Tp>
<Amt Ccy="EUR">469035826.79</Amt>
<CdtDbtInd>CRDT</CdtDbtInd>
<Dt>
<Dt>2017-09-27</Dt>
</Dt>
</Bal>
<Bal>
<Tp>
<CdOrPrtry>
<Prtry>AOIC</Prtry>
</CdOrPrtry>
</Tp>
<Amt Ccy="EUR">0.00</Amt>
<CdtDbtInd>CRDT</CdtDbtInd>
<Dt>
<Dt>2017-09-27</Dt>
</Dt>
</Bal>
<Bal>
<Tp>
<CdOrPrtry>
<Prtry>SPCA</Prtry>
</CdOrPrtry>
</Tp>
<Amt Ccy="EUR">469035826.79</Amt>
<CdtDbtInd>CRDT</CdtDbtInd>
<Dt>
<Dt>2017-09-27</Dt>
</Dt>
</Bal>
<TxsSummry>
<TtlNtriesPerBkTxCd>
<NbOfNtries>0</NbOfNtries>
<Sum>0.00</Sum>
<CdtDbtInd>CRDT</CdtDbtInd>
<BkTxCd>
<Prtry>
<Cd>AVLI</Cd>
</Prtry>
</BkTxCd>
</TtlNtriesPerBkTxCd>
<TtlNtriesPerBkTxCd>
<NbOfNtries>313</NbOfNtries>
<Sum>469035826.79</Sum>
<CdtDbtInd>CRDT</CdtDbtInd>
<BkTxCd>
<Prtry>
<Cd>AVSI</Cd>
</Prtry>
</BkTxCd>
</TtlNtriesPerBkTxCd>
</TxsSummry>
</Rpt>
</BkToCstmrAcctRpt>
</Document>
这是我的源代码:
using (XmlReader reader = XmlReader.Create(_ms))
{
var docXml = XDocument.Load(reader);
var prefix = ((XElement)(docXml.Root.FirstNode)).Name.LocalName;
var nameSpace = ((XElement)(docXml.Root.FirstNode)).Name.NamespaceName;
XmlNameTable nameTable = reader.NameTable;
XmlNamespaceManager namespaceManager = new XmlNamespaceManager(nameTable);
namespaceManager.AddNamespace(string.Empty, nameSpace);
var filterOpt = docXml.Root.Document.XPathSelectElements("BkToCstmrAcctRpt", namespaceManager);
}
如果我读的XPath //文档工作正常,但如果我试图读取文件///BkToCstmrAcctRpt或另一个子节点的结果is count = 0
答
请尝试下列修复命名空间问题。 :
const string FILENAME = @"c:\temp\test.xml";
static void Main(string[] args)
{
XDocument doc = XDocument.Load(FILENAME);
XElement BkToCstmrAcctRpt = doc.Descendants().Where(x => x.Name.LocalName == "BkToCstmrAcctRpt").FirstOrDefault();
XNamespace ns = BkToCstmrAcctRpt.GetDefaultNamespace();
XElement LastPgInd = BkToCstmrAcctRpt.Descendants(ns + "LastPgInd").FirstOrDefault();
}
+0
非常感谢@jdweng – darthlitox
〔含有的XDocument命名空间]可能的复制(https://stackoverflow.com/questions/2998710/xdocument-containing-namespaces) – rene
这不是一个重复的问题。 XML是不同的,它不是节点头名称空间。 – darthlitox
的解决方案是一样的... – rene