🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

1回答

2489閲覧

flickr apiで元画像のサイズ、中画像サイズを1万単位でダウンロードするには?

nw_ch

総合スコア6

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2019/10/23 03:20

編集2019/10/23 03:28

前提・実現したいこと

flickrで1万単位で画像の収集を可能にしたい
はじめ、150,150の画像サイズで400枚の画像のダウンロードはできたが
画像のサイズを元画像のサイズでダウンロードするとエラーが発生した。

エラーの回避方法とflickrから数万単位の画像の収集を可能にしたいです。
よろしくお願いします。

発生している問題・エラーメッセージ

Traceback (most recent call last): File "gatherflickr.py", line 44, in <module> url_c = photo['url_c'] KeyError: 'url_c'

該当のソースコード

from flickrapi import FlickrAPI from urllib.request import urlretrieve from pprint import pprint import os, time, sys # API キーの情報 key ="" secret = "" # 重要:リクエストを送るタイミングが短すぎると画像取得先のサーバを逼迫してしまうか、 # スパムとみなされてしまう可能性があるので、待ち時間を 1 秒間設ける。 wait_time = 8 # コマンドライン引数の 1 番目の値を取得 animalname = sys.argv[1] # 画像を保存するディレクトリを指定 savedir = "./" + animalname # FlickrAPI にアクセス # FlickrAPI(キー、シークレット、データフォーマット{json で受け取る}) flickr = FlickrAPI(key, secret, format='parsed-json') result = flickr.photos.search( # 検索キーワード text = animalname, # 取得するデータ件数 per_page = 10000, # 検索するデータの種類(ここでは、写真) media = 'photos', # データの並び順(関連順) sort = 'relevance', # UI コンテンツを表示しない safe_search = 1, # 取得したいオプションの値(url_q->画像のアドレスが入っている情報、licence -> ライセンス情報) extras = 'url_c, licence' ) # 結果を表示 photos = result['photos'] # pprint(photos) # 追記 for photo in photos['photo']: url_c = photo['url_c'] filepath = savedir + '/' + photo['id'] + '.jpg' # ファイルが重複していたらスキップする if os.path.exists(filepath): continue # データをダウンロードする urlretrieve(url_c, filepath) # 重要:サーバを逼迫しないように 1 秒待つ time.sleep(wait_time)

試したこと

はじめurl_qに指定(画像サイズを(150,150))で400枚入手はできた。
time.sleepを8秒に伸ばしたりした

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

回答がつかないようなので...

KeyError: 'url_c'

エラーメッセージから判断すると キーが無いためエラーになっているようですね。

Flickr のいくつかの写真を見てみた感じでは、Medium 800 サイズがない場合は、url_c が存在しないので取得できないようですが、API から取得した結果の photo には、'url_c' の項目は存在しているのでしょうか?

こちらで試した感じでは、例えば 640 x 480 の画像をアップロードすると url_c は、存在しませんでした。

エラーの回避方法としては、

のいずれかの方法を利用することになると思います。

投稿2019/10/26 00:24

CHERRY

総合スコア25216

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問