Autocomplete (New) サービスは、HTTP リクエストに応じて場所の候補とクエリ予測を返すウェブサービスです。リクエストでは、テキスト検索文字列に加え、検索対象地域を限定する地理的境界を指定します。
Autocomplete(新規)サービスは、入力の完全な単語と部分文字列を照合して、場所の名前、住所、Plus Codes を解決できます。これにより、アプリケーションはユーザーの入力に合わせて随時クエリを送信し、場所とクエリの候補をリアルタイムで表示することができます。
Autocomplete(新版)API からのレスポンスには、次の 2 種類の予測を含めることができます。
- 場所の予測: 指定された入力テキスト文字列と検索エリアに基づく、お店やサービス、住所、スポットなどの場所。デフォルトでは、場所の予測が返されます。
- クエリの予測: 入力テキスト文字列と検索領域に一致するクエリ文字列。デフォルトでは、クエリの予測は返されません。
includeQueryPredictions
リクエスト パラメータを使用して、クエリ予測をレスポンスに追加します。
たとえば、ユーザー入力の一部である「Sicilian piz」を含む文字列を入力として API を呼び出し、検索エリアをカリフォルニア州サンフランシスコに限定します。レスポンスには、検索文字列と検索エリアに一致する場所の予測のリスト(「Sicilian Pizza Kitchen」というレストランなど)と、その場所の詳細が含まれます。
返される場所の予測は、ユーザーが目的の場所を選択できるようにユーザーに提示することを目的としています。返された場所の予測の詳細情報を取得するには、Place Details (New) リクエストを実行します。
レスポンスには、検索文字列と検索エリアに一致するクエリ予測のリスト(「シチリア風ピザとパスタ」など)も含まれます。レスポンスの各クエリ予測には、推奨されるテキスト検索文字列を含む text
フィールドが含まれています。その文字列を Text Search(新版)の入力として使用して、より詳細な検索を実行します。
API Explorer では、ライブ リクエストを実行して、API と API オプションを把握できます。
Autocomplete(新規)リクエスト
自動入力(新規)リクエストは、次の形式の URL に対する HTTP POST リクエストです。
https://places.googleapis.com/v1/places:autocomplete
すべてのパラメータを JSON リクエスト本文または POST リクエストの一部としてヘッダーで渡します。次に例を示します。
curl -X POST -d '{ "input": "pizza", "locationBias": { "circle": { "center": { "latitude": 37.7937, "longitude": -122.3965 }, "radius": 500.0 } } }' \ -H 'Content-Type: application/json' -H "X-Goog-Api-Key: API_KEY" \ https://places.googleapis.com/v1/places:autocomplete
レスポンスについて
Autocomplete(新規)は、レスポンスとして JSON オブジェクトを返します。レスポンスの説明:
suggestions
配列には、認識された関連性に基づいて、予測されたすべての場所とクエリが順序付けられて含まれています。各場所はplacePrediction
フィールドで表され、各クエリはqueryPrediction
フィールドで表されます。placePrediction
フィールドには、プレイス ID やテキストの説明など、単一のプレイス予測に関する詳細情報が含まれます。queryPrediction
フィールドには、単一のクエリ予測に関する詳細情報が含まれます。
完全な JSON オブジェクトの形式は次のとおりです。
{ "suggestions": [ { "placePrediction": { "place": "places/ChIJ5YQQf1GHhYARPKG7WLIaOko", "placeId": "ChIJ5YQQf1GHhYARPKG7WLIaOko", "text": { "text": "Amoeba Music, Haight Street, San Francisco, CA, USA", "matches": [ { "endOffset": 6 }] }, ... }, { "queryPrediction": { "text": { "text": "Amoeba Music", "matches": [ { "endOffset": 6 }] }, ... } ...] }
必須パラメータ
-
入力
検索するテキスト文字列。完全な単語と部分文字列、場所の名前、住所、Plus Codes を指定します。Autocomplete (New) サービスはこの文字列と一致する候補を、関連性の高い順に並べて結果として返します。
オプション パラメータ
-
FieldMask
レスポンス フィールド マスクを作成して、レスポンスで返すフィールドのリストを指定します。HTTP ヘッダー
X-Goog-FieldMask
を使用して、レスポンス フィールド マスクをメソッドに渡します。返される候補フィールドのカンマ区切りリストを指定します。たとえば、候補の
suggestions.placePrediction.place
とsuggestions.placePrediction.text
を取得します。X-Goog-FieldMask: places.displayName,places.formattedAddress
すべてのフィールドを取得するには、
*
を使用します。X-Goog-FieldMask: *
-
includedPrimaryTypes
場所には、表 A または表 B に記載されているタイプのうち、1 つのプライマリ タイプのみを指定できます。たとえば、プライマリ タイプは
"mexican_restaurant"
または"steak_house"
です。デフォルトでは、API は場所に関連付けられているプライマリ タイプ値に関係なく、
input
パラメータに基づいてすべての場所を返します。includedPrimaryTypes
パラメータを渡して、特定のプライマリ タイプまたはプライマリ タイプに結果を限定します。このパラメータを使用して、表 A または表 B の型値を最大 5 つ指定します。場所がレスポンスに含まれるには、指定されたプライマリ タイプ値のいずれかと一致している必要があります。
このパラメータには、代わりに
(regions)
または(cities)
のいずれかを含めることもできます。(regions)
タイプのコレクション フィルタは、地域や区分(地域や郵便番号など)を対象とします。(cities)
タイプのコレクションは、Google が都市として識別した場所をフィルタします。次の場合は、リクエストは
INVALID_REQUEST
エラーで拒否されます。- 指定したタイプの数が 5 個より多い。
- 任意の型は、
(cities)
または(regions)
に加えて指定します。 - 認識できないタイプが指定されている。
-
includePureServiceAreaBusinesses
true
に設定すると、顧客を直接訪問または配送するサービスを行っているものの、ビジネス拠点の住所ではサービスを提供していない非店舗型ビジネスがレスポンスに含まれます。false
に設定すると、物理的なビジネス拠点があるビジネスのみが返されます。 -
includeQueryPredictions
true
の場合、レスポンスには場所とクエリの両方の予測が含まれます。デフォルト値はfalse
です。つまり、レスポンスには場所の予測のみが含まれます。 -
includedRegionCodes
指定された地域のリストからのみ結果を取得します。このリストは、最大 15 個の ccTLD(「トップレベル ドメイン」)の 2 文字の値の配列として指定します。省略した場合、レスポンスには制限が適用されません。たとえば、地域をドイツとフランスに制限するには、次のようにします。
"includedRegionCodes": ["de", "fr"]
locationRestriction
とincludedRegionCodes
の両方を指定すると、結果は 2 つの設定の交差する領域に配置されます。 -
inputOffset
input
内のカーソル位置を示す 0 ベースの Unicode 文字オフセット。カーソルの位置は、返される予測に影響する可能性があります。空の場合、デフォルトはinput
の長さになります。 -
languageCode
結果を返す言語。
input
で使用されている言語がlanguageCode
で指定された値と異なる場合や、返された場所にローカル言語からlanguageCode
への翻訳がない場合は、結果が複数の言語で表示されることがあります。- 優先言語を指定するには、IETF BCP-47 言語コードを使用する必要があります。
-
languageCode
が指定されていない場合、API はAccept-Language
ヘッダーで指定された値を使用します。どちらも指定されていない場合、デフォルトはen
です。無効な言語コードを指定すると、API はINVALID_ARGUMENT
エラーを返します。 - 優先言語は、API が返す結果のセットと、返される順序にわずかに影響します。これは、API によるスペルミスの修正にも影響します。
-
この API は、ユーザーと現地の人々が読み取りやすく、ユーザー入力を反映した住所を提供しようとします。場所の予測の形式は、各リクエストのユーザー入力によって異なります。
-
input
パラメータの一致する用語が最初に選択され、languageCode
パラメータで指定された言語設定に沿った名前が使用されます(使用可能な場合)。それ以外の場合は、ユーザー入力に最も一致する名前が使用されます。 -
住所は、
input
パラメータのキーワードに一致するキーワードが選択された後、可能であればユーザーが読み取り可能なスクリプトで、現地の言語でフォーマットされます。 -
他のすべての住所は、
input
パラメータのキーワードと一致するキーワードが選択された後、優先言語で返されます。優先言語で名前を使用できない場合、API は最も近い一致を使用します。
-
locationBias または locationRestriction
検索領域を定義するには、
locationBias
またはlocationRestriction
を指定します。両方は指定できません。locationRestriction
は、結果が含まれる必要があるリージョンを指定します。locationBias
は、結果が近い必要があるリージョンを指定します。ただし、そのリージョンの外側にあってもかまいません。locationBias
検索する領域を指定します。この位置情報はバイアスとして機能します。つまり、指定された位置情報の周辺の結果(指定されたエリア外の検索結果を含む)が返される可能性があります。
locationRestriction
検索する領域を指定します。指定した範囲外の結果は返されません。
locationBias
またはlocationRestriction
のリージョンを長方形のビューポートまたは円として指定します。円は、中心点と半径(メートル単位)で定義されます。半径は 0.0 ~ 50000.0 の範囲で指定する必要があります。デフォルト値は 0.0 です。
locationRestriction
の場合、半径を 0.0 より大きい値に設定する必要があります。それ以外の場合、リクエストは結果を返しません。次に例を示します。
"locationBias": { "circle": { "center": { "latitude": 37.7937, "longitude": -122.3965 }, "radius": 500.0 } }
長方形は緯度経度ビューポートで、対角線上の 2 つの
low
と高ポイントで表されます。ビューポートは閉じた領域と見なされます。つまり、境界が含まれます。緯度の範囲は -90 ~ 90 度、経度の範囲は -180 ~ 180 度の範囲で指定する必要があります。low
=high
の場合、ビューポートは単一のポイントで構成されます。low.longitude
>high.longitude
の場合、経度の範囲が反転します(ビューポートが経度 180 度線を越えます)。low.longitude
= -180 度、high.longitude
= 180 度の場合、ビューポートにはすべての経度が含まれます。low.longitude
= 180 度、high.longitude
= -180 度の場合、経度の範囲は空になります。
low
とhigh
の両方を入力する必要があります。また、表すボックスを空にすることはできません。ビューポートが空の場合、エラーが発生します。たとえば、このビューポートはニューヨーク市を完全に囲んでいます。
"locationBias": { "rectangle": { "low": { "latitude": 40.477398, "longitude": -74.259087 }, "high": { "latitude": 40.91618, "longitude": -73.70018 } } }
-
origin
目的地までの直線距離を計算する始点(
distanceMeters
として返されます)。この値を省略すると、直線距離は返されません。緯度と経度の座標として指定する必要があります。"origin": { "latitude": 40.477398, "longitude": -74.259087 }
-
regionCode
レスポンスのフォーマットに使用される地域コード。ccTLD(「トップレベル ドメイン」)の 2 文字の値として指定します。ほとんどの ccTLD コードは ISO 3166-1 コードと同一ですが、いくつか注意が必要な例外もあります。たとえば、英国の ccTLD は「uk」(.co.uk)ですが、ISO 3166-1 コードは「gb」(技術的には「英国(グレートブリテンおよび北アイルランド連合王国)」のエンティティ)です。
無効なリージョン コードを指定すると、API は
INVALID_ARGUMENT
エラーを返します。このパラメータは、適用される法律に基づいて結果に影響する可能性があります。 -
sessionToken
セッション トークンは、Autocomplete(新規)の呼び出しを「セッション」として追跡するユーザー作成の文字列です。Autocomplete(新規)は、セッション トークンを使用して、ユーザーの予測入力検索のクエリと選択フェーズを、請求処理のために個別のセッションにグループ化します。詳細については、セッション トークンをご覧ください。
自動入力(新規)の例
locationRestriction を使用して検索を特定のエリアに制限する
locationRestriction
には、検索する領域を指定します。指定した範囲外の結果は返されません。次の例では、locationRestriction
を使用して、サンフランシスコを中心とする半径 5, 000 m の円にリクエストを制限します。
curl -X POST -d '{ "input": "Art museum", "locationRestriction": { "circle": { "center": { "latitude": 37.7749, "longitude": -122.4194 }, "radius": 5000.0 } } }' \ -H 'Content-Type: application/json' -H "X-Goog-Api-Key: API_KEY" \ https://places.googleapis.com/v1/places:autocomplete
指定したエリア内のすべての結果は、suggestions
配列に含まれます。
{ "suggestions": [ { "placePrediction": { "place": "places/ChIJkQQVTZqAhYARHxPt2iJkm1Q", "placeId": "ChIJkQQVTZqAhYARHxPt2iJkm1Q", "text": { "text": "Asian Art Museum, Larkin Street, San Francisco, CA, USA", "matches": [ { "startOffset": 6, "endOffset": 16 } ] }, "structuredFormat": { "mainText": { "text": "Asian Art Museum", "matches": [ { "startOffset": 6, "endOffset": 16 } ] }, "secondaryText": { "text": "Larkin Street, San Francisco, CA, USA" } }, "types": [ "establishment", "museum", "point_of_interest" ] } }, { "placePrediction": { "place": "places/ChIJI7NivpmAhYARSuRPlbbn_2w", "placeId": "ChIJI7NivpmAhYARSuRPlbbn_2w", "text": { "text": "de Young Museum, Hagiwara Tea Garden Drive, San Francisco, CA, USA", "matches": [ { "endOffset": 15 } ] }, "structuredFormat": { "mainText": { "text": "de Young Museum", "matches": [ { "endOffset": 15 } ] }, "secondaryText": { "text": "Hagiwara Tea Garden Drive, San Francisco, CA, USA" } }, "types": [ "establishment", "point_of_interest", "tourist_attraction", "museum" ] } }, /.../ ] }
locationRestriction
を使用して、検索を長方形のビューポートに制限することもできます。次の例では、リクエストをサンフランシスコのダウンタウンに制限しています。
curl -X POST -d '{ "input": "Art museum", "locationRestriction": { "rectangle": { "low": { "latitude": 37.7751, "longitude": -122.4219 }, "high": { "latitude": 37.7955, "longitude": -122.3937 } } } }' \ -H 'Content-Type: application/json' -H "X-Goog-Api-Key: API_KEY" \ https://places.googleapis.com/v1/places:autocomplete
結果は suggestions
配列に格納されます。
{ "suggestions": [ { "placePrediction": { "place": "places/ChIJkQQVTZqAhYARHxPt2iJkm1Q", "placeId": "ChIJkQQVTZqAhYARHxPt2iJkm1Q", "text": { "text": "Asian Art Museum, Larkin Street, San Francisco, CA, USA", "matches": [ { "startOffset": 6, "endOffset": 16 } ] }, "structuredFormat": { "mainText": { "text": "Asian Art Museum", "matches": [ { "startOffset": 6, "endOffset": 16 } ] }, "secondaryText": { "text": "Larkin Street, San Francisco, CA, USA" } }, "types": [ "point_of_interest", "museum", "establishment" ] } }, { "placePrediction": { "place": "places/ChIJyQNK-4SAhYARO2DZaJleWRc", "placeId": "ChIJyQNK-4SAhYARO2DZaJleWRc", "text": { "text": "International Art Museum of America, Market Street, San Francisco, CA, USA", "matches": [ { "startOffset": 14, "endOffset": 24 } ] }, "structuredFormat": { "mainText": { "text": "International Art Museum of America", "matches": [ { "startOffset": 14, "endOffset": 24 } ] }, "secondaryText": { "text": "Market Street, San Francisco, CA, USA" } }, "types": [ "museum", "point_of_interest", "tourist_attraction", "art_gallery", "establishment" ] } } ] }
locationBias を使用して特定の地域に検索結果を偏向させる
locationBias
では、場所がバイアスとして機能します。つまり、指定された場所の周辺の結果(指定されたエリア外の場所も含む)が返されます。次の例では、リクエストをサンフランシスコのダウンタウンにバイアスします。
curl -X POST -d '{ "input": "Amoeba", "locationBias": { "circle": { "center": { "latitude": 37.7749, "longitude": -122.4194 }, "radius": 5000.0 } } }' \ -H 'Content-Type: application/json' -H "X-Goog-Api-Key: API_KEY" \ https://places.googleapis.com/v1/places:autocomplete
結果に、半径 5, 000 m の範囲外のスポットなど、多くのスポットが含まれるようになりました。
{ "suggestions": [ { "placePrediction": { "place": "places/ChIJ5YQQf1GHhYARPKG7WLIaOko", "placeId": "ChIJ5YQQf1GHhYARPKG7WLIaOko", "text": { "text": "Amoeba Music, Haight Street, San Francisco, CA, USA", "matches": [ { "endOffset": 6 } ] }, "structuredFormat": { "mainText": { "text": "Amoeba Music", "matches": [ { "endOffset": 6 } ] }, "secondaryText": { "text": "Haight Street, San Francisco, CA, USA" } }, "types": [ "electronics_store", "point_of_interest", "store", "establishment", "home_goods_store" ] } }, { "placePrediction": { "place": "places/ChIJr7uwwy58hYARBY-e7-QVwqw", "placeId": "ChIJr7uwwy58hYARBY-e7-QVwqw", "text": { "text": "Amoeba Music, Telegraph Avenue, Berkeley, CA, USA", "matches": [ { "endOffset": 6 } ] }, "structuredFormat": { "mainText": { "text": "Amoeba Music", "matches": [ { "endOffset": 6 } ] }, "secondaryText": { "text": "Telegraph Avenue, Berkeley, CA, USA" } }, "types": [ "electronics_store", "point_of_interest", "establishment", "home_goods_store", "store" ] } }, ... ] }
locationBias
を使用して、検索を長方形のビューポートに制限することもできます。次の例では、リクエストをサンフランシスコのダウンタウンに制限しています。
curl -X POST -d '{ "input": "Amoeba", "locationBias": { "rectangle": { "low": { "latitude": 37.7751, "longitude": -122.4219 }, "high": { "latitude": 37.7955, "longitude": -122.3937 } } } }' \ -H 'Content-Type: application/json' -H "X-Goog-Api-Key: API_KEY" \ https://places.googleapis.com/v1/places:autocomplete
長方形のビューポート内の検索結果はレスポンスに表示されますが、バイアスが適用されるため、一部の結果は定義された境界の外側に表示されます。結果は suggestions
配列にも含まれます。
{ "suggestions": [ { "placePrediction": { "place": "places/ChIJ5YQQf1GHhYARPKG7WLIaOko", "placeId": "ChIJ5YQQf1GHhYARPKG7WLIaOko", "text": { "text": "Amoeba Music, Haight Street, San Francisco, CA, USA", "matches": [ { "endOffset": 6 } ] }, "structuredFormat": { "mainText": { "text": "Amoeba Music", "matches": [ { "endOffset": 6 } ] }, "secondaryText": { "text": "Haight Street, San Francisco, CA, USA" } }, "types": [ "point_of_interest", "store", "establishment" ] } }, { "placePrediction": { "place": "places/ChIJr7uwwy58hYARBY-e7-QVwqw", "placeId": "ChIJr7uwwy58hYARBY-e7-QVwqw", "text": { "text": "Amoeba Music, Telegraph Avenue, Berkeley, CA, USA", "matches": [ { "endOffset": 6 } ] }, "structuredFormat": { "mainText": { "text": "Amoeba Music", "matches": [ { "endOffset": 6 } ] }, "secondaryText": { "text": "Telegraph Avenue, Berkeley, CA, USA" } }, "types": [ "point_of_interest", "store", "establishment" ] } }, { "placePrediction": { "place": "places/ChIJRdmfADq_woARYaVhnfQSUTI", "placeId": "ChIJRdmfADq_woARYaVhnfQSUTI", "text": { "text": "Amoeba Music, Hollywood Boulevard, Los Angeles, CA, USA", "matches": [ { "endOffset": 6 } ] }, "structuredFormat": { "mainText": { "text": "Amoeba Music", "matches": [ { "endOffset": 6 } ] }, "secondaryText": { "text": "Hollywood Boulevard, Los Angeles, CA, USA" } }, "types": [ "point_of_interest", "store", "establishment" ] } }, /.../ ] }
includedPrimaryTypes を使用する
includedPrimaryTypes
パラメータを使用して、表 A、表 B のタイプ値を最大 5 つ指定するか、(regions)
のみ、または (cities)
のみを指定します。場所がレスポンスに含まれるには、指定されたプライマリ タイプ値のいずれかと一致している必要があります。
次の例では、「サッカー」の input
文字列を指定し、includedPrimaryTypes
パラメータを使用して、結果を "sporting_goods_store"
タイプの施設に制限します。
curl -X POST -d '{ "input": "Soccer", "includedPrimaryTypes": ["sporting_goods_store"], "locationBias": { "circle": { "center": { "latitude": 37.7749, "longitude": -122.4194 }, "radius": 500.0 } } }' \ -H 'Content-Type: application/json' -H "X-Goog-Api-Key: API_KEY" \ https://places.googleapis.com/v1/places:autocomplete
includedPrimaryTypes
パラメータを省略すると、結果に、望ましくないタイプの施設("athletic_field"
など)が含まれる場合があります。
クエリ予測をリクエストする
デフォルトでは、クエリの予測は返されません。includeQueryPredictions
リクエスト パラメータを使用して、クエリの予測をレスポンスに追加します。次に例を示します。
curl -X POST -d '{ "input": "Amoeba", "includeQueryPredictions": true, "locationBias": { "circle": { "center": { "latitude": 37.7749, "longitude": -122.4194 }, "radius": 5000.0 } } }' \ -H 'Content-Type: application/json' -H "X-Goog-Api-Key: API_KEY" \ https://places.googleapis.com/v1/places:autocomplete
suggestions
配列には、上記のレスポンスについてで説明したように、プレイスの予測とクエリの予測の両方が含まれるようになりました。各クエリ予測には、推奨されるテキスト検索文字列を含む text
フィールドが含まれています。返されたクエリ予測の詳細情報を取得するには、Text Search (New) リクエストを送信します。
オリジンを使用する
この例では、リクエストに緯度と経度の座標として origin
を含めます。origin
を含めると、API のレスポンスに distanceMeters
フィールドが含まれます。このフィールドには、origin
から目的地までの直線距離が含まれます。この例では、送信元をサンフランシスコの中心に設定します。
curl -X POST -d '{ "input": "Amoeba", "origin": { "latitude": 37.7749, "longitude": -122.4194 }, "locationRestriction": { "circle": { "center": { "latitude": 37.7749, "longitude": -122.4194 }, "radius": 5000.0 } } }' \ -H 'Content-Type: application/json' -H "X-Goog-Api-Key: API_KEY" \ https://places.googleapis.com/v1/places:autocomplete
レスポンスには distanceMeters
が含まれます。
{ "suggestions": [ { "placePrediction": { "place": "places/ChIJ5YQQf1GHhYARPKG7WLIaOko", "placeId": "ChIJ5YQQf1GHhYARPKG7WLIaOko", "text": { "text": "Amoeba Music, Haight Street, San Francisco, CA, USA", "matches": [ { "endOffset": 6 } ] }, "structuredFormat": { "mainText": { "text": "Amoeba Music", "matches": [ { "endOffset": 6 } ] }, "secondaryText": { "text": "Haight Street, San Francisco, CA, USA" } }, "types": [ "home_goods_store", "establishment", "point_of_interest", "store", "electronics_store" ], "distanceMeters": 3012 } } ] }
試してみよう:
API Explorer では、サンプル リクエストを実行して、API と API オプションを把握できます。
試してみよう:
API Explorer では、サンプル リクエストを実行して、API と API オプションを把握できます。
ページの右側にある API アイコン api を選択します。
必要に応じて、リクエスト パラメータを編集します。
[Execute] ボタンを選択します。ダイアログで、リクエストに使用するアカウントを選択します。
API Explorer パネルで、全画面アイコン fullscreen を選択して API Explorer ウィンドウを開きます。