У меня возникли проблемы с преобразованием xslt, и я был бы очень признателен за помощь. Я провел довольно много времени, используя различные методы в XPath и XQuery. Кроме того, я ограничен xslt 1.0.
Преобразование включает в себя внесение изменений в позиции продукта в файле заказа xml. Исходный XML-файл содержит элементы, однако некоторые элементы строки являются ссылками на купоны на скидку (см. dsc-102 и dsc-133 ниже). Чего мне нужно добиться, так это удалить узлы «orderDetails» для ссылок на купоны на скидку и добавить содержащую информацию к соответствующим элементам продукта одного уровня (см. пример преобразованного XML ниже). Каждая ссылка на купон на скидку указывает соответствующие позиции продукта в конце названия продукта (например, ….[glv-001][glv-003]).
Исходный XML-файл. Ниже приведен исходный XML-файл, содержащий 1 заказ с 3 товарными позициями и 2 ссылками на купоны на скидку. Код скидки «dsc-102» соответствует 2 позициям продукта «glv-001» и «glv-003». Код скидки «dsc-133» соответствует 1 позиции продукта «sho-123».
<xmldata>
<Order>
<orderID>1010</orderID>
<custFirstName>Jim</custFirstName>
<custLastName>Jones</custLastName>
<orderDetails>
<productCode>sho-123</productCode>
<productName>Leather Windsor Shoes - size 10</productName>
</orderDetails>
<orderDetails>
<productCode>glv-001</productCode>
<productName>Leather gloves - size Small</productName>
</orderDetails>
<orderDetails>
<productCode>glv-003</productCode>
<productName>Leather gloves - size XLarge</productName>
</orderDetails>
<orderDetails>
<productCode>dsc-102</productCode>
<productName>10% Discount for Leather Gloves [glv-001][glv-003]</productName>
</orderDetails>
<orderDetails>
<productCode>dsc-133</productCode>
<productName>Free Shipping for Windsor Shoes [sho-123]</productName>
</orderDetails>
</Order>
Transformed XML File - Below is the transformed XML that I want to achieve. The transfer has removed both discount coupon references and added a 'discountCoupon' node to their corresponding sibling product items.
<xmldata>
<Orders>
<orderID>1010</orderID>
<custFirstName>Jim</custFirstName>
<custLastName>Jones</custLastName>
<orderDetails>
<productCode>sho-123</productCode>
<productName>Leather Windsor Shoes - size 10</productName>
<discountCoupon>Free Shipping for Windsor Shoes</discountCoupon>
</orderDetails>
<orderDetails>
<productCode>glv-001</productCode>
<productName>Leather gloves - size Small</productName>
<discountCoupon>10% Discount for Leather Gloves</discountCoupon>
</orderDetails>
<orderDetails>
<productCode>glv-003</productCode>
<productName>Leather gloves - size XLarge</productName>
<discountCoupon>10% Discount for Leather Gloves</discountCoupon>
</orderDetails>
</Orders>
What I have Tried So far - To be totally honest I have had quite limited success with this problem. The closest I have got with it has been with the following. However, it was pretty far off my intended result and 'matches' is a XLST 2.0 function and I am restricted to version 1.
<xsl:if test="../OrderDetails[ProductCode = 'DSC-15'] and matches(ProductCode,'AH010585059',i)">DiscountCoupon</xsl:if>
Если бы кто-то мог помочь мне с этой проблемой или подтолкнуть меня в правильном направлении, я был бы очень признателен.
-Ваше здоровье.