Linq to XML读取XPath(读取所有节点)

时间:2017-09-29 09:44:09

标签: c# xml linq xpath linq-to-xml

这是我的XML文件,包含一个xmlns。我试图读取文件动态的所有节点。

第一个节点(Document)工作正常,但其他节点没有。

可以帮助我。

    <?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 //文档工作正常,但如果我试图读取// Document / BkToCstmrAcctRpt或其他子节点,结果是count = 0

1 个答案:

答案 0 :(得分:1)

尝试以下修复命名空间问题。 :

        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();
        }