如果我使用0而不是x(在while循环中)程序正常工作,我从flickr获取第一张照片来自某人最喜欢的列表,但如果我想要比第一张照片更多或更多,我会收到此错误
import flickrlib
import webbrowser
FLICKR_API_KEY = "f86203e922041a6a999fd4a59f19b1e6"
FLICKR_API_SSECRET = "b286bcaddafb00c8"
flickruser = raw_input("Who are you interested in? ")
amount = int(raw_input("How many pictures would you like to see? "))
total = amount
counter = 0
imagepile = ""
x= 0
client = flickrlib.FlickrAgent(FLICKR_API_KEY, FLICKR_API_SSECRET)
person = client.flickr.people.findByUsername( username= flickruser)
userid = person[u'id']
photos = client.flickr.favorites.getPublicList(user_id= userid, per_page=1)
while counter < total:
farm = photos[u'photo'] [x] [u'farm']
server = photos[u'photo'] [x] [u'server']
photo_id = photos[u'photo'] [x] [u'id']
secret = photos[u'photo'] [x] [u'secret']
imgsrc = "<img src='http://farm" + farm + ".static.flickr.com/" + server + "/" + photo_id + "_" + secret +".jpg' /><br />"
imagepile = imagepile + imgsrc
counter= counter+1
x=x+1
htmlopen = "<html><head><title>"+ flickruser + "</title></head><body><h1>" + flickruser + "'s Public List. ""</h1>"
simple_page = htmlopen + imagepile + "</body></html>"
xml_file = open("webpage.html", "w")
xml_file.write(simple_page)
xml_file.close()
webbrowser.open("webpage.html")
答案 0 :(得分:5)
我不知道Flickr的API,但看起来你只需要getPublicList
中的1张照片。无论哪种方式,您都不会检查以确保total
小于getPublicList
返回的图片数量。
答案 1 :(得分:3)
因为您在此处使用per_page=1
:
photos = client.flickr.favorites.getPublicList(user_id= userid, per_page=1)
你只得到一张照片。