如何在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