0

この投稿の下部にあるhpricotxmlを考えると、.eachを使用せずに「アイテム」を選択するにはどうすればよいですか?ドキュメントのすべての部分は、のバリエーションを使用します

@res.items.each do |item|
  # do stuff
end

この場合、「アイテム」は1つしかないため、これは無意味です。これを正しくしようとして最後の年齢のためにyの髪を引き裂いてきました。

さらに情報を追加するために編集:

さて、初期のコメントから判断すると、どこかでポイントが欠けているので、より多くの情報を提供します。

私はamazon-ecsと呼ばれるrubygemを使用して、Amazonから商品情報を取得しています。宝石のサイトでは、次のように説明されています

Hpricotを使用した一般的なRubyAmazonProduct Advertising API(以前はEコマースREST APIと呼ばれていました)。これは、REST API XML出力に簡単にアクセスできるように、ResponseラッパークラスとElementラッパークラスを使用します。これは汎用であるため、Amazon :: Ecsを拡張して、実装されていない他の操作を簡単にサポートできます。応答オブジェクトは、XML要素マップに1対1のオブジェクト/属性を提供するのではなく、Hp​​ricot要素オブジェクトをラップするだけです。

正直に言うと、それが何を意味するのかはよくわかりませんが、Responseオブジェクトのラッピングに関するビットがこれを難しくしているのではないかと思います。

基本的に、私がこれを行うとき:

@res = Amazon::Ecs.item_lookup(ean, options_hash)

次に、「debug @res」を出力すると、以下のようになります。

お役に立てば幸いです。 編集を終了

Hpricot xml:

<Amazon::Ecs::Response:0xa4449cc @doc=#<Hpricot::Doc 
{xmldecl "<?xml version=\"1.0\" ?>"} 
{elem <itemlookupresponse xmlns="http://webservices.amazon.com/AWSECommerceService/2005-10-05"> 
  {elem <operationrequest> 
    {elem <httpheaders> 
      {emptyelem <header name="UserAgent" value="Ruby">} 
    </HTTPHeaders>} 
    {elem <requestid> "b89bad91-f5a1-4daf-87f2-d309dded35d6" </RequestId>} 
    {elem <arguments> 
      {emptyelem <argument name="Operation" value="ItemLookup">} 
      {emptyelem <argument name="SearchIndex" value="Books">} 
      {emptyelem <argument name="Signature" value="dasdasdsadsadsafdfdsfsdsasadsadsd">} 
      {emptyelem <argument name="ItemId" value="9780307463746">} 
      {emptyelem <argument name="IdType" value="ISBN">} 
      {emptyelem <argument name="AWSAccessKeyId" value="sdasdsadsadsadsadsadd">} 
      {emptyelem <argument name="Timestamp" value="2011-02-17T15:08:09Z">} 
      {emptyelem <argument name="Service" value="AWSECommerceService">} 
    </Arguments>} 
    {elem <requestprocessingtime> "0.0252220000000000" </RequestProcessingTime>} 
  </OperationRequest>} 
  {elem <items> 
    {elem <request> 
      {elem <isvalid> "True" </IsValid>} 
      {elem <itemlookuprequest> 
        {elem <condition> "New" </Condition>} 
        {elem <deliverymethod> "Ship" </DeliveryMethod>} 
        {elem <idtype> "ISBN" </IdType>} 
        {elem <merchantid> "Amazon" </MerchantId>} 
        {elem <offerpage> "1" </OfferPage>} 
        {elem <itemid> "9780307463746" </ItemId>} 
        {elem <responsegroup> "Small" </ResponseGroup>} 
        {elem <reviewpage> "1" </ReviewPage>} 
        {elem <searchindex> "Books" </SearchIndex>} 
      </ItemLookupRequest>} 
    </Request>} 
    {elem <item> 
      {elem <asin> "0307463745" </ASIN>} 
      {elem <detailpageurl> "http://www.amazon.com/Rework-Jason-Fried/dp/0307463745%3FSubscriptionId%3DAKIAIV6GP6CJC3AINUUQ%26tag%3Dws%26linkCode%3Dxm2%26camp%3D2025%26creative%3D165953%26creativeASIN%3D0307463745" </DetailPageURL>} 
      {elem <smallimage> 
        {elem <url> "http://ecx.images-amazon.com/images/I/41Qz6afdrLL._SL75_.jpg" </URL>} 
        {elem <height units="pixels"> "75" </Height>} 
        {elem <width units="pixels"> "50" </Width>} 
      </SmallImage>} 
      {elem <mediumimage> 
        {elem <url> "http://ecx.images-amazon.com/images/I/41Qz6afdrLL._SL160_.jpg" </URL>} 
        {elem <height units="pixels"> "160" </Height>} 
        {elem <width units="pixels"> "106" </Width>} 
      </MediumImage>} {elem <largeimage> {elem <url> "http://ecx.images-amazon.com/images/I/41Qz6afdrLL.jpg" </URL>} {elem <height units="pixels"> "500" </Height>} {elem <width units="pixels"> "331" </Width>} </LargeImage>} {elem <imagesets> {elem <imageset category="primary"> {elem <swatchimage> {elem <url> "http://ecx.images-amazon.com/images/I/41Qz6afdrLL._SL30_.jpg" </URL>} {elem <height units="pixels"> "30" </Height>} {elem <width units="pixels"> "20" </Width>} </SwatchImage>} {elem <smallimage> {elem <url> "http://ecx.images-amazon.com/images/I/41Qz6afdrLL._SL75_.jpg" </URL>} {elem <height units="pixels"> "75" </Height>} {elem <width units="pixels"> "50" </Width>} </SmallImage>} {elem <mediumimage> {elem <url> "http://ecx.images-amazon.com/images/I/41Qz6afdrLL._SL160_.jpg" </URL>} {elem <height units="pixels"> "160" </Height>} {elem <width units="pixels"> "106" </Width>} </MediumImage>} {elem <largeimage> {elem <url> "http://ecx.images-amazon.com/images/I/41Qz6afdrLL.jpg" </URL>} {elem <height units="pixels"> "500" </Height>} {elem <width units="pixels"> "331" </Width>} </LargeImage>} </ImageSet>} </ImageSets>}
      {elem <itemattributes> 
        {elem <author> "Jason Fried" </Author>} 
        {elem <author> "David Heinemeier Hansson" </Author>} 
        {elem <manufacturer> "Crown Business" </Manufacturer>} 
        {elem <productgroup> "Book" </ProductGroup>} 
        {elem <title> "Rework" </Title>} 
      </ItemAttributes>} 
    </Item>} 
  </Items>} 
</ItemLookupResponse>}
4

2 に答える 2

2

まず、@ res(ドキュメントから)からHpricotオブジェクトを抽出します。

doc = @res.doc

次に、Hpricotオブジェクトを使用できるようになります。

puts (doc/:item).inner_html
于 2011-02-18T13:09:21.277 に答える
0

あなたはこのようなことをすることができます

item = (doc/:header).first

上記はheader、XMLドキュメントの最初のノードを取得するはずです。それはテストされていないので、私はそれにいくつかのテストをします

于 2011-02-18T12:54:28.220 に答える