다음과 같은 XML 파일이 있습니다 sample.xml
.
<m:properties>
<d:>ABCD</d:>
<d:>1234</d:>
<d:>0048</d:>
<d:>0.0</d:>
</m:properties>
<m:properties>
<d:>EFGH</d:>
<d:>5678</d:>
<d:>1111</d:>
<d:>9.0</d:>
</m:properties>
원하는 출력은 다음과 같습니다.
ABCD,1234,0048,0.0
EFGH,5678,1111,9.0
누구든지 스크립트 작성을 도와줄 수 있나요?
답변1
XML이 이름이 지정된 단일 루트 태그에 포함되어 있다고 가정하면 root
유사한 허용 XML 파서를 사용합니다 xq
(yq
https://kislyuk.github.io/yq/) CSV 생성:
xq -r '.root."m:properties"[]."d:" | @csv' sample.xml
그러한 닫는 태그가 없으면 동적으로 추가할 수 있습니다.
{
echo '<root>'
cat sample.xml
echo '</root>'
} | xq -r '.root."m:properties"[]."d:" | @csv'
결과:
"ABCD","1234","0048","0.0"
"EFGH","5678","1111","9.0"