Решение Python 3.x (с модулем xml.etree.ElementTree):
import xml.etree.ElementTree as ET
tree = ET.parse("test.xml")
root = tree.getroot()
for app in root.findall('application'):
for m,s in zip(app.iter('machine'), app.iter('status')):
print("%s,%s,%s" % (app.get('name'), m.text, s.text))
Вывод:
Adapter/Code1,123,Running
Adapter/Code1,456,Running
Adapter/Code2,123,Running
Adapter/Code2,456,Running
xmlstarlet + awk (используется для группировки дочерних узлов для каждого элемента application
) решение:
xmlstarlet sel -t -v "//application/@name| .//machine/text()| .//status/text()" -n input.xml
| awk '/Adapter/{app=$0; r=app; c=0; next}
{ if(++c==2){ c=0; print r","$0; r=app } else { r=r","$0 }}'
Вывод:
Adapter/Code1,123,Running
Adapter/Code1,456,Running
Adapter/Code2,123,Running
Adapter/Code2,456,Running
"//application/@name| .//machine/text()| .//status/text()"
- выражение XPath для получения необходимых узлов
/Adapter/{app=$0; р = приложение; с=0; next}
- захват имени каждого приложения
для дальнейшей конкатенации