Python 中的 Flickr API 如何从 Flickr 下载照片 3

How to download photos from Flickr by Flickr API in Python 3

菜鸟问题系列...

我是 python 的新手,最近想创建一个 python 小应用程序,可以根据不同的搜索输入从 flickr 收集照片。 (例如:如果我输入 "dog",它将从 flickr 下载所有狗图片)

我在网上做了一些研究,发现 flickr API 可能是最好的方法,而 flickr.photos.getSizes 应该是我需要使用的方法.

然而,我在编码时有几个愚蠢的问题:

  1. 我已经为 flickr API 应用了我的密钥和秘密,我只是不知道下一步要做什么 flickr.photos.getSizes 在 python 中下载照片。比如,如何在 python 中调用这个方法? (我注意到此方法所需的参数是键和 photo_id,如何根据搜索输入 "dog" 获取 photo_id)

  2. 然后我按照 https://github.com/alexis-mignon/python-flickr-api/wiki/Tutorial 的教程进行操作,但是当我导入 flickr_api 时,我收到错误消息:

    Could not load all modules
    <class 'ImportError'> No module named 'objects'
    Traceback (most recent call last):
      File "D:/Agfa/Projects/Image/flickr.py", line 2, in <module>
        import flickr_api
      File "D:\Application\Anaconda3\lib\site-packages\flickr_api\__init__.py", line 32, in <module>
        from auth import set_auth_handler
    ImportError: cannot import name 'set_auth_handler'
    

    然后我看了一下_init_.py:

    try:
        from objects import *
        import objects
        import upload as Upload
        from upload import upload, replace
    except Exception as e:
        print "Could not load all modules"
        print type(e), e
    
    from auth import set_auth_handler
    from method_call import enable_cache, disable_cache
    from keys import set_keys
    from _version import __version__
    

    好像这个库不支持python 3 但是我不知道怎么办。 (我无法在我的 python 上安装 methond_call、keys、_version 3)我想我会使用 flickrapi

非常感谢您的光临,再次感谢。

我对 why/how 没有任何线索。如果你想将 flickr_api 模块与 python3.5+ 一起使用,你需要修复导入,就像我在下面所做的那样:

try:
    from objects import *
    import objects
    import upload as Upload
    from upload import upload, replace
except Exception as e:
    #print "Could not load all modules"
    print( type(e), e)

from .auth import set_auth_handler
from .method_call import enable_cache, disable_cache
from .keys import set_keys
from ._version import __version__

此编辑后,它失败并出现另一个导入错误:

>>> import flickr_api
<class 'SyntaxError'> invalid syntax (method_call.py, line 50)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/home/krysopath/.local/lib/python3.5/site-packages/flickr_api/__init__.py", line 32, in <module>
    from .auth import set_auth_handler
  File "/home/krysopath/.local/lib/python3.5/site-packages/flickr_api/auth.py", line 43, in <module>
    import urlparse
ImportError: No module named 'urlparse'

所以你可以自己解决这个问题,如果你愿意,只需沿着导入错误走并添加一个点将它们转换为绝对导入,这不会失败。

我想,如果你想使用这个模块,你必须先修复它......然后有一个未知的 return。因此,如果您还没有投入大量资金,使用其他模块可能会更有效。

我想我终于找到了使用 Flickr 的正确方法API:

有很多方法,但我想出了 2:

def flickr_walk(keyward):
    count = 0
    photos = flickr.walk(text=keyward,
                 tag_mode='all',
                 tags=keyward,
                 extras='url_c',
                 per_page=100)

    for photo in photos:
        try:
            url=photo.get('url_c')
            urllib.request.urlretrieve(url, path+'\' + str(count) +".jpg")
        except Exception as e:
            print('failed to download image')

flickr.walk用Photos.searchAPI,我也可以直接用API:

def flickr_search(keyward):
    obj = flickr.photos.search(text=keyward,
                           tags=keyward,
                           extras='url_c',
                           per_page=5)

    for photo in obj:
        url=photo.get('url_c')
        photos = ET.dump(obj)
        print (photos)

记得先拿到key和secret:

api_key = 'xxxxxxxxxxxxxxxx'
api_secret = 'xxxxxxxxxxxxx'

flickr=flickrapi.FlickrAPI(api_key,api_secret,cache=True)