XML Editor
Sign up for a WebBoard account Sign Up Keyword Search Search More Options... Options
Chat Rooms Chat Help Help News News Log in to WebBoard Log in Not Logged in
Conferences Close Tree View
+ Stylus Studio Feature Requests (1192)
+ Stylus Studio Technical Forum (14621)
+ Website Feedback (249)
- XSLT Help and Discussion (7625)
-> + Use of before and after string (3) Sticky Topic
-> - How do I substitute element ty... (1)
-> + How does one add working days ... (4)
-> - Help, I have existing XLT and... (1)
-> + Need help on XSLT issue - (2)
-> + EDI to XML Conversion (7)
-> - XML To JSON Conversion using X... (1)
-> + Formatting Paragraphs to same ... (2)
-> - Grouping of records (1)
-> + Problems with xsd 1.1 (4)
-> + XML to HL7 mapping (3)
-> + XSLT 3 and Iterate (2)
-> + XSL-FO to PDF preview (3)
-> + java.lang.RuntimeException: Er... (2)
-> + Create Acroforms with Stylus X... (2)
-> + How to change XSLT parameter s... (3)
-> + how to change format of the da... (2)
-> + Search "Next 8 Results " doesn... (2)
-> - Support for Git (1)
-> + newbee (8)
-- [1-20] [21-40] [41-60] Next
+ XQuery Help and Discussion (2017)
+ Stylus Studio FAQs (159)
+ Stylus Studio Code Samples & Utilities (364)
+ Stylus Studio Announcements (113)
Topic  
Postnext
tyler horathSubject: using document and web service...
Author: tyler horath
Date: 22 Oct 2008 01:53 PM
Originally Posted: 22 Oct 2008 01:51 PM
So heres what Im trying to do. I am trying to search amazon for an ASIN using a name field I am provided. I want to get the ASIN using the search request url. Once I get the ASIN, I want to use that ASIN to get the product review. Heres my xslt. ITs not working because it puts all the ASINS in one url instead of puttting each ASIN in each url.

My XML is as follows
<catalog>
<product>
<name>White Widgets</name>
</product>
<product>
<name>Blue Widgets</name>
</product>
</catalog>

XSLT:


<xsl:template match="catalog/product" name="reviews">
<xsl:param name="keyword"><xsl:value-of select="translate(translate(name,' ','+'),' '' ', '')"/>
</xsl:param>
<xsl:variable name="url2" select="concat(' http://ecs.amazonaws.com/onca/xml?Service=AWSECommerceService&amp;AWSAccessKeyId=[MY KEY]&amp;Operation=ItemSearch&amp;Keywords=',$keyword,'&amp;SearchIndex=Blended')"></xsl:variable>
<xsl:variable name="ASIN">
<xsl:value-of select="document($url2, .)/a:ItemSearchResponse/a:Items/a:Item/a:ASIN"/>
</xsl:variable>
<xsl:variable name="url" select="concat(' http://ecs.amazonaws.com/onca/xml?Service=AWSECommerceService&amp;AWSAccessKeyId=[MY KEY]&amp;Operation=ItemLookup&amp;ItemId=',$ASIN,'&amp;ResponseGroup=Request,EditorialReview,Reviews,SalesRank&amp;Version=2008-08-19')">
</xsl:variable>
<xsl:for-each select="document($url)/b:ItemLookupResponse/b:Items/b:Item/b:CustomerReviews/b:Review/b:Content">
<xsl:value-of select="."/>
</xsl:for-each>
</xsl:template>

Posttop
(Deleted User) Subject: using document and web service...
Author: (Deleted User)
Date: 23 Oct 2008 12:26 PM
Hi Tyler,
if you use document($url2, .)/a:ItemSearchResponse/a:Items/a:Item/a:ASIN you will fetch all ASIN from the reply and store in the $ASIN variable; I guess you want to do a <xsl:for-each select="document($url2, .)/a:ItemSearchResponse/a:Items"> followed by the <xsl:variable select="a:Item/a:ASIN"/>.

Hope this helps,
Alberto

   
Download A Free Trial of Stylus Studio 6 XML Professional Edition Today! Powered by Stylus Studio, the world's leading XML IDE for XML, XSLT, XQuery, XML Schema, DTD, XPath, WSDL, XHTML, SQL/XML, and XML Mapping!  
go

Log In Options

Site Map | Privacy Policy | Terms of Use | Trademarks
Stylus Scoop XML Newsletter:
W3C Member
Stylus Studio® and DataDirect XQuery ™are from DataDirect Technologies, is a registered trademark of Progress Software Corporation, in the U.S. and other countries. © 2004-2016 All Rights Reserved.