У меня проблемы с разработкой преобразования xslt, и я был бы очень признателен за помощь. Я потратил довольно много времени, используя различные методы в XPath и XQuery. Кроме того, я ограничен xslt 1.0.
Преобразование включает в себя внесение изменений в позиции продукта в файле заказа xml. Исходный файл XML содержит элементы, однако некоторые из элементов строки являются ссылками на купоны на скидку (см. Dsc-102 и dsc-133 ниже). Что мне нужно сделать, так это удалить узлы orderDetails для ссылок на купоны на скидку и добавить содержащую информацию к соответствующим элементам их родственных продуктов (см. Образец Transformed 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>
Преобразованный файл XML -
Ниже приведен преобразованный XML, которого я хочу достичь. Передача удалила обе ссылки на купоны на скидку и добавила узел "discountCoupon" к соответствующим элементам их родственного товара.
<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>
Что я уже пробовал -
Честно говоря, у меня был довольно ограниченный успех с этой проблемой. Самое близкое, что у меня есть, было следующее. Тем не менее, это было довольно далеко от моего предполагаемого результата, и «совпадения» - это функция XLST 2.0, и я ограничен версией 1.
<xsl:if test="../OrderDetails[ProductCode = 'DSC-15'] and matches(ProductCode,'AH010585059',i)">DiscountCoupon</xsl:if>
Если бы кто-то мог мне помочь с этой проблемой или дать толчок в правильном направлении, я был бы очень признателен.
-Cheers.