XML 파일에서 특정 값, 즉 XML 태그 뒤의 값(예: = 기호 뒤)을 추출하는 방법

XML 파일에서 특정 값, 즉 XML 태그 뒤의 값(예: = 기호 뒤)을 추출하는 방법

나는 ReferenceId="0128140321960O"또한RelatedReferenceId="SWCC"

<FinancialTransfersInstruction xmlns="middleware.frk.com/Schemas/Onetis/1.0">
<SWIFTHeader DeliveryMethod="SWIFT" MessageType="202" OrigSendDate="2019-11-15" Receiver="SBOSUS3UIMS" ReferenceId="0207060050180O" Sender="TESTBIC" SenderName="TEST INVESTORS, INC" TransType="NEW"/>
<PortalHeader BusinessUnit="GTS"/> <Wires> <Wire Currency="USD" Id="20706s5018.0" RelatedReferenceId="CCPM" </Wire> </Wires>
<FinancialTransfersInstruction/></FinancialTransfersInstruction>

값을 추출하는 명령을 실행하면 참조도 제공됩니다. ReferenceId 태그 값만 필요합니다.

cat *.xml |grep -P -o -e '(?<=ReferenceId=").*?(?=")'

답변1

질문의 XML이 잘못되었습니다. 수정된 XML이 실제로 다음과 같다고 가정하면,

<?xml version="1.0"?>
<FinancialTransfersInstruction xmlns="https://middleware.frk.com/Schemas/Onetis/1.0">
  <SWIFTHeader DeliveryMethod="SWIFT" MessageType="202" OrigSendDate="2019-11-15" Receiver="SBOSUS3UIMS" ReferenceId="0207060050180O" Sender="TESTBIC" SenderName="TEST INVESTORS, INC" TransType="NEW"/>
  <PortalHeader BusinessUnit="GTS"/>
  <Wires>
    <Wire Currency="USD" Id="20706s5018.0" RelatedReferenceId="CCPM"/>
  </Wires>
</FinancialTransfersInstruction>

이를 사용하여 xmlstarletXML을 구문 분석하고 적절한 속성 값을 추출할 수 있습니다.

xmlstarlet sel -t -v '//_:SWIFTHeader/@ReferenceId' bankfile.xml
0207060050180O

관련 정보