ユーザーのカレンダー リストにあるカレンダーを返します。今すぐ試すまたは例を見る。
リクエスト
HTTP リクエスト
GET https://www.googleapis.com/calendar/v3/users/me/calendarList
パラメータ
パラメータ名 | 値 | 説明 |
---|---|---|
省略可能なクエリ パラメータ | ||
maxResults |
integer |
1 つの結果ページで返されるエントリの最大数。デフォルトでは、値は 100 エントリです。ページサイズは 250 エントリを超えることはできません。省略可能。 |
minAccessRole |
string |
返されたエントリ内のユーザーの最小アクセスロール。省略可。デフォルトでは制限はありません。
有効な値は次のとおりです。
|
pageToken |
string |
返される結果ページを指定するトークン。省略可能。 |
showDeleted |
boolean |
削除されたカレンダー リストのエントリを結果に含めるかどうか。省略可。デフォルトは False です。 |
showHidden |
boolean |
非表示のエントリを表示するかどうか。省略可。デフォルトは False です。 |
syncToken |
string |
前のリスト リクエストの結果の最後のページで返された nextSyncToken フィールドから取得したトークン。これにより、このリスト リクエストの結果には、それ以降に変更されたエントリのみが含まれます。カレンダー プロパティや ACL などの読み取り専用フィールドのみが変更された場合、エントリは返されません。前回のリスト リクエスト以降に削除または非表示になったエントリは、常に結果セットに含まれます。showDeleted と showHidden のどちらも False に設定することはできません。クライアント ステートの整合性を確保するため、 minAccessRole クエリ パラメータは nextSyncToken と同時に指定できません。syncToken が期限切れになると、サーバーは 410 GONE レスポンス コードで応答します。クライアントはストレージを消去し、syncToken なしで完全同期を実行する必要があります。増分同期の詳細 省略可。デフォルトでは、すべてのエントリが返されます。 |
承認
このリクエストは、少なくとも次のうち 1 つのスコープによる承認が必要です。
範囲 |
---|
https://www.googleapis.com/auth/calendar.readonly |
https://www.googleapis.com/auth/calendar |
https://www.googleapis.com/auth/calendar.calendarlist |
https://www.googleapis.com/auth/calendar.calendarlist.readonly |
詳しくは、認証と認可のページをご覧ください。
リクエストの本文
このメソッドをリクエストの本文に含めないでください。
レスポンス
成功すると、このメソッドは次の構造を含むレスポンスの本文を返します。
{ "kind": "calendar#calendarList", "etag": etag, "nextPageToken": string, "nextSyncToken": string, "items": [ calendarList Resource ] }
プロパティ名 | 値 | 説明 | メモ |
---|---|---|---|
kind |
string |
コレクションのタイプ(「calendar#calendarList 」)。 |
|
etag |
etag |
コレクションの ETag。 | |
nextPageToken |
string |
この結果の次のページにアクセスするために使用されるトークン。検索結果が他にない場合は省略され、その場合は nextSyncToken が指定されます。 |
|
items[] |
list |
ユーザーのカレンダー リストに表示されているカレンダー。 | |
nextSyncToken |
string |
この結果が返されてから変更されたエントリのみを取得するために、後で使用されるトークン。追加の結果が利用可能な場合は省略されます。その場合は nextPageToken が指定されます。 |
例
注: このメソッドで使用可能なコード例では、サポートされているプログラミング言語すべての例を示しているわけではありません(サポートされている言語の一覧については、クライアント ライブラリ ページをご覧ください)。
Java
Java クライアント ライブラリを使用します。
import com.google.api.services.calendar.Calendar; import com.google.api.services.calendar.model.CalendarList; import com.google.api.services.calendar.model.CalendarListEntry; // ... // Initialize Calendar service with valid OAuth credentials Calendar service = new Calendar.Builder(httpTransport, jsonFactory, credentials) .setApplicationName("applicationName").build(); // Iterate through entries in calendar list String pageToken = null; do { CalendarList calendarList = service.calendarList().list().setPageToken(pageToken).execute(); List<CalendarListEntry> items = calendarList.getItems(); for (CalendarListEntry calendarListEntry : items) { System.out.println(calendarListEntry.getSummary()); } pageToken = calendarList.getNextPageToken(); } while (pageToken != null);
Python
Python クライアント ライブラリを使用します。
page_token = None while True: calendar_list = service.calendarList().list(pageToken=page_token).execute() for calendar_list_entry in calendar_list['items']: print calendar_list_entry['summary'] page_token = calendar_list.get('nextPageToken') if not page_token: break
PHP
PHP クライアント ライブラリを使用します。
$calendarList = $service->calendarList->listCalendarList(); while(true) { foreach ($calendarList->getItems() as $calendarListEntry) { echo $calendarListEntry->getSummary(); } $pageToken = $calendarList->getNextPageToken(); if ($pageToken) { $optParams = array('pageToken' => $pageToken); $calendarList = $service->calendarList->listCalendarList($optParams); } else { break; } }
Ruby
Ruby クライアント ライブラリを使用します。
page_token = nil begin result = client.list_calendar_lists(page_token: page_token) result.items.each do |e| print e.summary + "\n" end if result.next_page_token != page_token page_token = result.next_page_token else page_token = nil end end while !page_token.nil?
試してみよう:
以下の API Explorer を使用して、ライブデータに対してこのメソッドを呼び出し、レスポンスを確認します。