使用 Xmlstarlet select 列出 XML 中的元素

Listing ELements from XML using Xmlstarlet select

我有以下 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 中的元素 select。

我尝试使用以下文件从该文件中列出 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 - 并用新行结束每个打印的匹配项

为什么这不起作用?

问题是您的 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