Python

PythonでGoogleAdwordsAPIを使って検索ボリュームを出してみた

More than 1 year has passed since last update.

こちらはウェブクルー Advent Calendar 2017の22日目の記事です。
昨日は、@morotinさんの「サイトをリッチにするjQueryライブラリの紹介」でした。

はじめに

社内向けに外部データを活用したツールを開発しようと思い、
その一機能としてGoogleAdwordsAPIを使って検索ボリュームを出す仕組みを作りました。
この記事では振り返りを兼ねて、実装に至るまでの流れをまとめます。

APIを使う事前準備としての設定手順は「最初のAPI呼び出しを実行する | Google Developers」を確認していただければと思います。

検索ボリュームを取得する

先に結果としてのコードから

from googleads import adwords

PAGE_SIZE = 100
offset = 0

def main(client, keywords):

    targeting_idea_service = client.GetService('TargetingIdeaService', version='v201710')

    selector = {
        'searchParameters':[
            {
                'xsi_type':'RelatedToQuerySearchParameter',
                'queries':keywords
            },
            {
                'xsi_type': 'LanguageSearchParameter',
                'languages': [{'id': '1005'}]
            },
            {
                'xsi_type': 'NetworkSearchParameter',
                'networkSetting':{
                    'targetGoogleSearch':True,
                    'targetSearchNetwork':False,
                    'targetContentNetwork':False,
                    'targetPartnerSearchNetwork':False
                }
            }
        ],
        'ideaType':'KEYWORD',
        'requestType':'STATS',
        'requestedAttributeTypes':[
            'TARGETED_MONTHLY_SEARCHES'
        ],
        'paging':{
            'startIndex':str(offset),
            'numberResults':str(PAGE_SIZE)
        }
    }
    page = targeting_idea_service.get(selector)
    if 'entries' in page:
        for result in page['entries']:
            attributes = {}
            for attributes in result['data']:
                attributes[attributes['key']] = getattr(attributes['value'], 'value', 0)
                print(attributes['TARGETED_MONTHLY_SEARCHES'])
    else:
        print('No keywords volume were found.')

if __name__ == '__main__':

    adwords_client = adwords.AdWordsClient.LoadFromStorage()
    keywords = ['テスト', 'hoge']
    main(adwords_client, keywords)

上記のコードプログラムを実行すると、キーワード「テスト、hoge」の年間(月別)の検索ボリュームを取得することができます。
キーワード候補の取得のPythonサンプルコードをもとに作成しましたので、大枠はそちらをご覧ください。

AdWordsAPIサービスの呼び出し

    targeting_idea_service = client.GetService('TargetingIdeaService', version='v201710')

検索ボリューム取得につかうのは最適化サービスの「TargetingIdeaService」です。
APIのバージョンは現時点(2017年12月)では「v201710」が最新ですね。
詳しくはサポート終了と廃止のスケジュールを確認していただければと思います。

パラメータの設定

'searchParameters':[
            {
                'xsi_type':'RelatedToQuerySearchParameter',
                'queries':keywords
            },
            {
                'xsi_type': 'LanguageSearchParameter',
                'languages': [{'id': '1005'}]
            },
            {
                'xsi_type': 'NetworkSearchParameter',
                'networkSetting':{
                    'targetGoogleSearch':True,
                    'targetSearchNetwork':False,
                    'targetContentNetwork':False,
                    'targetPartnerSearchNetwork':False
                }
            }
        ]

RelatedToQuerySearchParameter
キーワードはリスト形式で渡してあげれば、複数でも値を返してくれます。
1キーワードずつ渡すとすぐにAPIの利用制限にひっかかり、時間を空けないとデータを取得することができないようになります。

LanguageSearchParameter
公式のサンプルコードでは「1000」が記述されていますが、日本語は「1005」です。
他の言語はCode and FormatsのLanguages欄にあるCSVをダウンロードして確認してください。

NetworkSearchParameter
今回は検索ネットワーク専用のキーワードに対してということとして「targetGoogleSearch」のみTrueとしています。

'ideaType':'KEYWORD',
'requestType':'STATS',
'requestedAttributeTypes':['TARGETED_MONTHLY_SEARCHES'],
'paging':{
    'startIndex':str(offset),
    'numberResults':str(PAGE_SIZE)
}

サンプルコードに書いてあるキーワード候補の取得との変更点は
requestTyperequestedAttributeTypesになります。
STATSとすることによって過去の統計情報を取得し、
TARGETED_MONTHLY_SEARCHESで月間検索ボリュームを取得することができます。

最後の結果出力に関してはサンプルコードとほぼ変わりません。
attributes['TARGETED_MONTHLY_SEARCHES']
指定するKEYを変更しているだけです。

まとめ

今回は検索ボリュームを取得するところまでといった単発的な利用時のコードを書きました。
毎回プログラムたたいて出力する分は上記で問題ないでしょう。
Webアプリとして使う際に注意すべきなのは、APIのレート制限とyamlファイルの読み込みですね。

私はキーワードは1つずつしか渡せないと思っていた(サンプルコードに引っ張られて。。。)ので、最初はすぐに制限に引っかかっていました。使い方にもよるかと思いますが、私と同じ過ちは繰り返して欲しくないのでリスト形式で渡すことをおすすめします。

あとyamlファイルは、最初のAPI呼び出しを実行する | Google Developersで出てくるのですが、同じディレクトリにあれば気にしなくても動くのですが、違う場所におく場合にはパスを指定してあげると動きます。

明日は、@yurayuramenさんです。よろしくお願いいたします。

参考文献

最後に

ウェブクルーでは一緒に働いていただける方を随時募集しております。
お気軽にエントリーくださいませ。

開発エンジニアの募集
フロントエンドエンジニアの募集
データベースエンジニアの募集