编程语言
首页 > 编程语言> > 如何在Python 3中通过Flickr API从Flickr下载照片

如何在Python 3中通过Flickr API从Flickr下载照片

作者:互联网

菜鸟问题系列…

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

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

但是,编码时我没有几个愚蠢的问题:

>我已经为flickr API应用了密钥和秘诀,我只是不知道接下来如何在python中使用flickr.photos.getSizes来下载照片.像,如何在python中调用此方法? (我注意到此方法所需的参数是键和photo_id,如何基于搜索输入“ dog”获取photo_id))
>然后我遵循了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 3上安装methond_call,keys,_version)我猜我会使用flickrapi

非常感谢您一次又一次的感谢.

解决方法:

我想我终于有了使用FlickrAPI的正确方法:

有很多方法,但我知道了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.search API,我也可以直接使用该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)

请记住首先获取密钥和秘密:

api_key = 'xxxxxxxxxxxxxxxx'
api_secret = 'xxxxxxxxxxxxx'

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

标签:python-3-x,api,flickr,python
来源: https://codeday.me/bug/20191026/1936501.html