4

我基本上无法看到 Shopify 图像 url 的存储方式以及我应该写什么来访问它。我不是 python 专家,所以它可能很简单,我没有看到。

Shopify 有一个 API,允许应用程序开发人员从商店访问产品、订单等。我可以获取我商店所有产品的列表并获取标题和价格等信息,但我无法获取图片网址。这是正在发生的事情和我需要的一些基本代码:

import shopify

#other code that accesses my shop

products = shopify.Product.find() #Here I grab a list of all the products
for product in products:
    title = product.title
    price = float(product.variants[0].price) #I'm not sure on the price either, but it works for now
    image_urls = create_image_url_list(product.images) # And here's where I want to create the list of strings using product.images

create_image_url_list(product_images):
    image_urls = []
    for image in product_images:
        product_image_url = '' # Somehow get source url from product image here as string
        image_urls.append(product_image_url)
    return image_urls

我相信每个产品都有一张图片列表。我想要做的是为每个产品创建一个图像源 URL 列表作为字符串。查看 Product 的Shopify API 文档,我看到该product.images属性如下所示:

{ "images" : "[ { "src": "http://example.com/burton.jpg" } ]"}

当我执行 pdb.set_trace() on 时product.images,它看起来像这样(我更改了隐私数字):

[image(12345678), image(12345678), image(12345678), image(12345678)]

当我对其中一个图像执行 dir() 时,我得到了这个:

['_ShopifyResource__get_id', '_ShopifyResource__set_id', '_ShopifyResource__to_xml_element', '__class__', '__cmp__', '__delattr__', '__dict__', '__doc__', '__format__', '__getattr__', '__getattribute__', '__hash__', '__init__', '__metaclass__', '__module__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', '_build_list', '_build_object', '_class_delete', '_class_get', '_class_head', '_class_post', '_class_put', '_collection_path', '_connection', '_custom_method_collection_url', '_custom_method_element_url', '_custom_method_new_element_url', '_element_path', '_find_class_for', '_find_class_for_collection', '_find_every', '_find_one', '_find_single', '_format', '_headers', '_id_from_response', '_initialized', '_instance_delete', '_instance_get', '_instance_head', '_instance_post', '_instance_put', '_load_attributes_from_response', '_password', '_plural', '_prefix', '_prefix_options', '_prefix_parameters', '_prefix_source', '_primary_key', '_query_string', '_singular', '_site', '_split_options', '_threadlocal', '_timeout', '_update', '_user', 'activate_session', 'attach_image', 'attributes', 'clear_session', 'count', 'create', 'delete', 'destroy', 'errors', 'exists', 'find', 'find_first', 'find_one', 'get', 'get_id', 'head', 'id', 'is_new', 'is_valid', 'klass', 'post', 'put', 'reload', 'save', 'set_id', 'to_dict', 'to_xml']

编辑:

在 Pawelmhm 的帮助下,访问源 url 的结果代码是:

products = shopify.Product.find() #Here I grab a list of all the products
for product in products:
    title = product.title
    price = float(product.variants[0].price)
    image_urls = [getattr(i, 'src') for i in product.images] # Reduced it to list comprehension using solution
4

1 回答 1

1

我想我知道您在这里寻找什么,product_images 是一个“类字典”对象,其中“图像”作为键,字典列表作为值。你有没有尝试过这样的事情?

for image in product_images:
     #product_image_url = '' 
     image_urls.append(image["images"])

也许?

for image in product_images.to_dict():
     image_urls.append(image["images"]["src"])

告诉我它是否有效,如果它没有告诉我你遇到了什么错误。我很好奇这个。另外,当您以自己的方式执行此操作时(您在此处发布的代码中的方式),您会得到什么?我的意思是没有这个空字符串当然会废除一切,但是没有空字符串,你会得到什么列表?

编辑:啊,这应该工作!

for image in product_images: 
     image_urls.append(image["src"])
于 2013-07-12T19:29:48.947 回答