Мне нужно преобразовать данные XML в другой формат. Я сделал очень мало XSL, и мой поиск в интернете не дал мне необходимых результатов. У меня есть этот образец XML:
<MailStatusReport>
<Output>
<ColMetaData ColCount="5">
<ColList>
<Col Name="parcelid" Pos="1"/>
<Col Name="currentlocationid" Pos="2"/>
<Col Name="deliverystatus" Pos="4"/>
<Col Name="requestedlocationid" Pos="3"/>
<Col Name="requestor" Pos="5"/>
</ColList>
</ColMetaData>
<RowList>
<Row>
<ColList>
<Col Pos="2">Delaware</Col>
<Col Pos="1">001</Col>
<Col Pos="3">NewYork</Col>
<Col Pos="4">InRoute</Col>
<Col Pos="5">John</Col>
</ColList>
</Row>
<Row>
<ColList>
<Col Pos="1">002</Col>
<Col Pos="2">Sanjose</Col>
<Col Pos="3">Michigan</Col>
<Col Pos="4">Delivered</Col>
<Col Pos="5">Rob</Col>
</ColList>
</Row>
</RowList>
</Output>
</MailStatusReport>
Желаемый вывод:
<MailStatusReport>
<Row parcelid="001" currentlocationid="Delaware" requestedlocationid="NewYork" deliverystatus="InRoute" requestor="John"/>
<Row parcelid="002" currentlocationid="Sanjose" requestedlocationid="Michigan" deliverystatus="Delivered" requestor="Rob"/>
</MailStatusReport>
Несколько замечаний:
- Атрибут Name ColMetaData / ColList / Col во входном xml заканчивается как имя атрибута для каждого элемента Row выходного xml.
- Значение RowList / Row / ColList / Col во входном xml заканчивается значением атрибута в выходном xml для атрибута, который имеет тот же Pos, что и в разделе ColMetaData / ColList / Col.
- Атрибут ColCount ColMetaData заслуживает доверия и может быть использован в качестве счетчика при необходимости.
Псевдокод, о котором я мог подумать, будет:
For each CurrentRow in the RowList
Begin Building OutputRow
For each Col in ColMetaData/ColList
attrName = ColMetaData/ColList/Col/Name
attrPos = ColMetaData/ColList/Col/Pos
attrVal = CurrentRow/ColList/Col[@Pos=$attrPos]
Add $attrName=$attrVal to the outputRow
Буду признателен за любую помощь, которую смогу получить!
Спасибо
Шринивас