使用Xmlstarlet从XML列出ELements选择

时间:2018-01-30 10:09:28

标签: xml select xpath element xmlstarlet

我有以下XML:

<?xml version="1.0" encoding="utf-8"?>
<Document xmlns="urn:iso:std:iso:20022:tech:xsd:pain.008.001.02" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <CstmrDrctDbtInitn>
    <GrpHdr>
      <MsgId>331-2018-01-01-01:59:01</MsgId>
      <CreDtTm>2018-01-22T12:59:01</CreDtTm>
      <NbOfTxs>1</NbOfTxs>
      <CtrlSum>11.13</CtrlSum>
      <InitgPty>
        <Nm>Company B.V.</Nm>
      </InitgPty>
    </GrpHdr>
    <PmtInf>
      <PmtInfId>331-264-1</PmtInfId>
      <PmtMtd>DD</PmtMtd>
      <BtchBookg>true</BtchBookg>
      <NbOfTxs>1</NbOfTxs>
      <CtrlSum>11.13</CtrlSum>
      <PmtTpInf>
        <SvcLvl>
          <Cd>SEPA</Cd>
        </SvcLvl>
        <LclInstrm>
          <Cd>CORE</Cd>
        </LclInstrm>
        <SeqTp>FRST</SeqTp>
      </PmtTpInf>
      <ReqdColltnDt>2018-01-01</ReqdColltnDt>
      <Cdtr>
        <Nm>Company B.V.</Nm>
        <PstlAdr>
          <Ctry>NL</Ctry>
          <AdrLine>Street 1</AdrLine>
          <AdrLine>2345 AA City</AdrLine>
        </PstlAdr>
      </Cdtr>
      <CdtrAcct>
        <Id>
          <IBAN>NL25RABO0123456789</IBAN>
        </Id>
      </CdtrAcct>
      <CdtrAgt>
        <FinInstnId>
          <BIC>RABONL2U</BIC>
        </FinInstnId>
      </CdtrAgt>
      <ChrgBr>SLEV</ChrgBr>
      <CdtrSchmeId>
        <Id>
          <PrvtId>
            <Othr>
              <Id>NL99ZZZ112233445566</Id>
              <SchmeNm>
                <Prtry>SEPA</Prtry>
              </SchmeNm>
            </Othr>
          </PrvtId>
        </Id>
      </CdtrSchmeId>
      <DrctDbtTxInf>
        <PmtId>
          <EndToEndId>1111C2233444.555.996666</EndToEndId>
        </PmtId>
        <InstdAmt Ccy="EUR">11.13</InstdAmt>
        <DrctDbtTx>
          <MndtRltdInf>
            <MndtId>02001111-0000110</MndtId>
            <DtOfSgntr>2018-01-01</DtOfSgntr>
            <AmdmntInd>false</AmdmntInd>
          </MndtRltdInf>
        </DrctDbtTx>
        <DbtrAgt>
          <FinInstnId>
            <BIC>ABNANL2A</BIC>
          </FinInstnId>
        </DbtrAgt>
        <Dbtr>
          <Nm>Student</Nm>
          <PstlAdr>
            <Ctry>NL</Ctry>
            <AdrLine>Street 1</AdrLine>
            <AdrLine>1111 AA CITY</AdrLine>
          </PstlAdr>
          <Id>
            <OrgId>
              <BICOrBEI>ABNANL2A</BICOrBEI>
            </OrgId>
          </Id>
        </Dbtr>
        <DbtrAcct>
          <Id>
            <IBAN>NL91ABNA0417164300</IBAN>
          </Id>
        </DbtrAcct>
        <RmtInf>
          <Ustrd>1111/ 1000000 Pat P0000100/1200000 XX001155/01200000XX Pat P0000100/1200000 1111 AA CITY</Ustrd>
        </RmtInf>
      </DrctDbtTxInf>
    </PmtInf>
  </CstmrDrctDbtInitn>
</Document>

我想使用Xmlstarlet select来列出此XML中的元素。

我尝试使用以下方法在此文件中列出Ustrd:

xmlstarlet sel -t -m "//CstmrDrctDbtInitn/PmtInf/DrctDbtTxInf/PmtId" -v EndToEndId -n SDDCore001.xml 

-m // CstmrDrctDbtInitn / PmtInf / DrctDbtTxInf / PmtId - 在任意深度查找元素CstmrDrctDbtInitn / PmtInf / DrctDbtTxInf / PmtId 在XML和每个这样的元素中。

-v EndToEndId - 打印调用的子元素的值 EndToEndId。

-n - 并用新行完成每个打印的匹配

为什么这不起作用?

1 个答案:

答案 0 :(得分:1)

问题是您的XML在根元素处声明了默认命名空间。这意味着XML中的所有元素都属于此命名空间,因此您尝试的XPath与任何元素都不匹配。

要使用XPath在名称空间中引用元素,您需要组合:引用正确名称空间URI的前缀和元素的本地名称。在xmlstarlet中,可以使用-N参数:

定义前缀映射
xmlstarlet sel -N d=urn:iso:std:iso:20022:tech:xsd:pain.008.001.02 \
 -t -m "//d:CstmrDrctDbtInitn/d:PmtInf/d:DrctDbtTxInf/d:PmtId" \
 -v d:EndToEndId -o "\n" -n SDDCore001.xml