スプレッドシートを更新する

スプレッドシートには、セルに含まれる値データ以外にも、次のようなさまざまな種類のデータが含まれています。

  • ディメンション
  • セルの形式と枠線
  • 名前付き範囲
  • 保護されている範囲
  • 条件付き書式

これらは、スプレッドシートの表示と動作を制御する多くの種類のデータの一部です。spreadsheets.batchUpdate メソッドを使用すると、これらのスプレッドシートの詳細を更新できます。変更はバッチでグループ化されるため、1 つのリクエストが失敗した場合、他の(依存関係がある可能性のある)変更は書き込まれません。

このページでは、spreadsheets.batchUpdate メソッドの基本的な使用方法について説明します。セル値データの読み取りと書き込みが必要な場合は、セル値の読み取りと書き込みで説明されている spreadsheets.values リソースを使用することもできます。

オペレーションのカテゴリ

spreadsheets.batchUpdate でサポートされている特定のオペレーションは、次のカテゴリに分類できます。

カテゴリ 説明
追加(および複製新しいオブジェクトを追加します(重複リクエストのように、古いオブジェクトに基づくこともあります)。
更新(および設定オブジェクトの特定のプロパティを更新します。通常、古いプロパティはそのまま残します(Set リクエストは以前のデータを上書きします)。
削除オブジェクトを削除します。

これらのカテゴリは、次のセクションで特定のオペレーションの動作を説明するために使用されます。

バッチ更新オペレーション

spreadsheets.batchUpdate メソッドは、1 つ以上の Request オブジェクトを受け取って動作します。各オブジェクトは、実行するリクエストの 1 つのタイプを指定します。リクエストにはさまざまな種類があります。リクエストの種類をカテゴリ別に分類した内訳は次のとおりです。

オブジェクト ADD / DUPLICATE UPDATE / SET 削除
スプレッドシートのプロパティ UpdateSpreadsheetPropertiesRequest
Google スプレッドシート AddSheetRequest
DuplicateSheetRequest
UpdateSheetPropertiesRequest DeleteSheetRequest
ディメンションディメンション範囲を含む) InsertDimensionRequest
AppendDimensionRequest
UpdateDimensionPropertiesRequest
MoveDimensionRequest
AutoResizeDimensionsRequest
DeleteDimensionRequest
セル(値、形式、データの入力規則などを含む) RepeatCellRequest
UpdateCellsRequest
AppendCellsRequest
名前付き範囲 AddNamedRangeRequest UpdateNamedRangeRequest DeleteNamedRangeRequest
枠線 UpdateBordersRequest
フィルタ(フィルタ表示基本フィルタなど) AddFilterViewRequest
DuplicateFilterViewRequest
UpdateFilterViewRequest
SetBasicFilterRequest
ClearBasicFilterRequest
データの検証 SetDataValidationRequest
Conditional Format Rules AddConditionalFormatRuleRequest UpdateConditionalFormatRuleRequest DeleteConditionalFormatRuleRequest
保護されている範囲 AddProtectedRangeRequest UpdateProtectedRangeRequest DeleteProtectedRangeRequest
埋め込みオブジェクト(グラフを含む) AddChartRequest UpdateChartSpecRequest
UpdateEmbeddedObjectPositionRequest
DeleteEmbeddedObjectRequest
結合 MergeCellsRequest UnmergeCellsRequest

データを操作するユーザー アクションを模倣する追加のリクエストもあります。

上限

Google スプレッドシートのセル数と行数の上限について詳しくは、Google ドライブに保管可能なファイルをご覧ください。

フィールド マスク

多くの「更新」リクエストにはフィールド マスクが必要です。これらは、オブジェクトの特定のフィールドのみを更新し、他のフィールドは変更しないようにするための、フィールドのカンマ区切りリストです。フィールド マスク * はワイルドカードとして扱われ、メッセージ内のすべてのフィールドを指定する省略形です(つまり、リクエストで値を指定しない場合、フィールドはデフォルトの状態に戻る可能性があります)。フィールド マスクの詳細については、フィールド マスクを使用するをご覧ください。

次のサンプルでは、UpdateSpreadsheetPropertiesRequest を使用してスプレッドシートのタイトルのみを更新します。

リクエスト:

POST .../v4/spreadsheets/spreadsheetId:batchUpdate

リクエスト本文:

{   "requests": [{       "updateSpreadsheetProperties": {           "properties": {"title": "TITLE"},           "fields": "title"       }   }] } 

TITLE は、スプレッドシートの新しいタイトルに置き換えます。

回答

スプレッドシートを更新する際、リクエストの種類によってはレスポンスが返されることがあります。これらは配列で返され、各レスポンスは対応するリクエストと同じインデックスを占有します。リクエストによってはレスポンスがないものもあり、その場合はレスポンスが空になります。

通常、「追加」リクエストには、追加されたオブジェクトの ID などの情報を返すレスポンスがあります。サポートされているレスポンスの一覧については、レスポンスをご覧ください。

次のコードサンプルは、次の処理を行います。

  1. title 変数を使用してスプレッドシートのタイトルを更新します。
  2. find 変数と replacement 変数を使用して、スプレッドシート内のセル値を検索して置き換えます。

Apps Script

sheets/api/spreadsheet_snippets.gs
/**  * Updates the specified sheet using advanced sheet services  * @param {string} spreadsheetId id of the spreadsheet to be updated  * @param {string} title name of the sheet in the spreadsheet to be updated  * @param {string} find string to be replaced  * @param {string} replacement the string to replace the old data  * @returns {*} the updated spreadsheet  */ Snippets.prototype.batchUpdate = (spreadsheetId, title,   find, replacement) => {   // This code uses the Sheets Advanced Service, but for most use cases   // the built-in method SpreadsheetApp.getActiveSpreadsheet()   //     .getRange(range).setValues(values) is more appropriate.    try {     // Change the spreadsheet's title.     let updateSpreadsheetPropertiesRequest =       Sheets.newUpdateSpreadsheetPropertiesRequest();     updateSpreadsheetPropertiesRequest.properties =       Sheets.newSpreadsheetProperties();     updateSpreadsheetPropertiesRequest.properties.title = title;     updateSpreadsheetPropertiesRequest.fields = 'title';      // Find and replace text.     let findReplaceRequest = Sheets.newFindReplaceRequest();     findReplaceRequest.find = find;     findReplaceRequest.replacement = replacement;     findReplaceRequest.allSheets = true;      let requests = [Sheets.newRequest(), Sheets.newRequest()];     requests[0].updateSpreadsheetProperties =       updateSpreadsheetPropertiesRequest;     requests[1].findReplace = findReplaceRequest;      let batchUpdateRequest = Sheets.newBatchUpdateSpreadsheetRequest();     batchUpdateRequest.requests = requests;      // Add additional requests (operations)     const result =       Sheets.Spreadsheets.batchUpdate(batchUpdateRequest, spreadsheetId);     return result;   } catch (err) {     // TODO (developer) - Handle exception     console.log('Failed with error %s', err.message);   } };

Java

sheets/snippets/src/main/java/BatchUpdate.java
import com.google.api.client.googleapis.json.GoogleJsonError; import com.google.api.client.googleapis.json.GoogleJsonResponseException; import com.google.api.client.http.HttpRequestInitializer; import com.google.api.client.http.javanet.NetHttpTransport; import com.google.api.client.json.gson.GsonFactory; import com.google.api.services.sheets.v4.Sheets; import com.google.api.services.sheets.v4.SheetsScopes; import com.google.api.services.sheets.v4.model.BatchUpdateSpreadsheetRequest; import com.google.api.services.sheets.v4.model.BatchUpdateSpreadsheetResponse; import com.google.api.services.sheets.v4.model.FindReplaceRequest; import com.google.api.services.sheets.v4.model.FindReplaceResponse; import com.google.api.services.sheets.v4.model.Request; import com.google.api.services.sheets.v4.model.SpreadsheetProperties; import com.google.api.services.sheets.v4.model.UpdateSpreadsheetPropertiesRequest; import com.google.auth.http.HttpCredentialsAdapter; import com.google.auth.oauth2.GoogleCredentials; import java.io.IOException; import java.util.ArrayList; import java.util.Collections; import java.util.List;  /* Class to demonstrate the use of Spreadsheet Batch Update API */ public class BatchUpdate {   /**    * Updates spreadsheet's title and cell values.    *    * @param spreadsheetId - Id of the spreadsheet.    * @param title         - New title of the spreadsheet.    * @param find          - Find cell values    * @param replacement   - Replaced cell values    * @return response metadata    * @throws IOException - if credentials file not found.    */   public static BatchUpdateSpreadsheetResponse batchUpdate(String spreadsheetId,                                                            String title,                                                            String find,                                                            String replacement)       throws IOException {         /* Load pre-authorized user credentials from the environment.            TODO(developer) - See https://developers.google.com/identity for             guides on implementing OAuth2 for your application. */     GoogleCredentials credentials = GoogleCredentials.getApplicationDefault()         .createScoped(Collections.singleton(SheetsScopes.SPREADSHEETS));     HttpRequestInitializer requestInitializer = new HttpCredentialsAdapter(         credentials);      // Create the sheets API client     Sheets service = new Sheets.Builder(new NetHttpTransport(),         GsonFactory.getDefaultInstance(),         requestInitializer)         .setApplicationName("Sheets samples")         .build();      List<Request> requests = new ArrayList<>();     BatchUpdateSpreadsheetResponse response = null;     try {       // Change the spreadsheet's title.       requests.add(new Request()           .setUpdateSpreadsheetProperties(new UpdateSpreadsheetPropertiesRequest()               .setProperties(new SpreadsheetProperties()                   .setTitle(title))               .setFields("title")));       // Find and replace text.       requests.add(new Request()           .setFindReplace(new FindReplaceRequest()               .setFind(find)               .setReplacement(replacement)               .setAllSheets(true)));        BatchUpdateSpreadsheetRequest body =           new BatchUpdateSpreadsheetRequest().setRequests(requests);       response = service.spreadsheets().batchUpdate(spreadsheetId, body).execute();       FindReplaceResponse findReplaceResponse = response.getReplies().get(1).getFindReplace();        System.out.printf("%d replacements made.", findReplaceResponse.getOccurrencesChanged());     } catch (GoogleJsonResponseException e) {       // TODO(developer) - handle error appropriately       GoogleJsonError error = e.getDetails();       if (error.getCode() == 404) {         System.out.printf("Spreadsheet not found with id '%s'.\n", spreadsheetId);       } else {         throw e;       }     }     return response;   } }

JavaScript

sheets/snippets/sheets_batch_update.js
function batchUpdate(spreadsheetId, title, find, replacement, callback) {   const requests = [];   // Change the spreadsheet's title.   requests.push({     updateSpreadsheetProperties: {       properties: {         title: title,       },       fields: 'title',     },   });   // Find and replace text.   requests.push({     findReplace: {       find: find,       replacement: replacement,       allSheets: true,     },   });   try {     // Add additional requests (operations) ...     const batchUpdateRequest = {requests: requests};     gapi.client.sheets.spreadsheets.batchUpdate({       spreadsheetId: spreadsheetId,       resource: batchUpdateRequest,     }).then((response) => {       const findReplaceResponse = response.result.replies[1].findReplace;       console.log(`${findReplaceResponse.occurrencesChanged} replacements made.`);       if (callback) callback(response);     });   } catch (err) {     document.getElementById('content').innerText = err.message;     return;   } }

Node.js

sheets/snippets/sheets_batch_update.js
/**  * Updates the Spreadsheet title. Finds and replaces a string in the sheets.  * @param {string} spreadsheetId The Spreadsheet to update  * @param {string} title The new Spreadsheet title  * @param {string} find The text to find  * @param {string} replacement The text to replace  * @return {obj} holding the information regarding the replacement of strings  */ async function batchUpdate(spreadsheetId, title, find, replacement) {   const {GoogleAuth} = require('google-auth-library');   const {google} = require('googleapis');    const auth = new GoogleAuth({     scopes: 'https://www.googleapis.com/auth/spreadsheets',   });    const service = google.sheets({version: 'v4', auth});   const requests = [];   // Change the spreadsheet's title.   requests.push({     updateSpreadsheetProperties: {       properties: {         title,       },       fields: 'title',     },   });   // Find and replace text.   requests.push({     findReplace: {       find,       replacement,       allSheets: true,     },   });   // Add additional requests (operations) ...   const batchUpdateRequest = {requests};   try {     const response = await service.spreadsheets.batchUpdate({       spreadsheetId,       resource: batchUpdateRequest,     });     const findReplaceResponse = response.data.replies[1].findReplace;     console.log(`${findReplaceResponse.occurrencesChanged} replacements made.`);     return response;   } catch (err) {     // TODO (developer) - Handle exception     throw err;   } }

PHP

sheets/snippets/src/SpreadsheetBatchUpdate.php
<?php use Google\Client; use Google\Service\Drive; use Google\Service\Sheets\BatchUpdateSpreadsheetRequest;  /**  * to batch update a spreadsheet  */ function batchUpdate($spreadsheetId, $title, $find, $replacement)     {            /* Load pre-authorized user credentials from the environment.            TODO(developer) - See https://developers.google.com/identity for             guides on implementing OAuth2 for your application. */         $client = new Google\Client();         $client->useApplicationDefaultCredentials();         $client->addScope(Google\Service\Drive::DRIVE);         $service = new Google_Service_Sheets($client);         try{             //execute the request             $requests = [                 new Google_Service_Sheets_Request([               'updateSpreadsheetProperties' => [                   'properties' => [                       'title' => $title                     ],                     'fields' => 'title'               ]           ]),           new Google_Service_Sheets_Request([               'findReplace' => [                   'find' => $find,                   'replacement' => $replacement,                   'allSheets' => true                   ]                   ])                 ];                 $batchUpdateRequest = new Google_Service_Sheets_BatchUpdateSpreadsheetRequest([                     'requests' => $requests                 ]);         $response = $service->spreadsheets->batchUpdate($spreadsheetId, $batchUpdateRequest);         $findReplaceResponse = $response->getReplies()[1]->getFindReplace();         printf("%s replacements made.\n",         $findReplaceResponse->getOccurrencesChanged());         return $response;     }     catch(Exception $e) {         // TODO(developer) - handle error appropriately         echo 'Message: ' .$e->getMessage();       }     }

Python

sheets/snippets/sheets_batch_update.py
import google.auth from googleapiclient.discovery import build from googleapiclient.errors import HttpError   def sheets_batch_update(spreadsheet_id, title, find, replacement):   """   Update the sheet details in batch, the user has access to.   Load pre-authorized user credentials from the environment.   TODO(developer) - See https://developers.google.com/identity   for guides on implementing OAuth2 for the application.   """    creds, _ = google.auth.default()   # pylint: disable=maybe-no-member    try:     service = build("sheets", "v4", credentials=creds)      requests = []     # Change the spreadsheet's title.     requests.append(         {             "updateSpreadsheetProperties": {                 "properties": {"title": title},                 "fields": "title",             }         }     )     # Find and replace text     requests.append(         {             "findReplace": {                 "find": find,                 "replacement": replacement,                 "allSheets": True,             }         }     )     # Add additional requests (operations) ...      body = {"requests": requests}     response = (         service.spreadsheets()         .batchUpdate(spreadsheetId=spreadsheet_id, body=body)         .execute()     )     find_replace_response = response.get("replies")[1].get("findReplace")     print(         f"{find_replace_response.get('occurrencesChanged')} replacements made."     )     return response    except HttpError as error:     print(f"An error occurred: {error}")     return error   if __name__ == "__main__":   sheets_batch_update("spreadsheet_id", "title", "find", "replacement")

Ruby

sheets/snippets/lib/spreadsheet_snippets.rb
requests = [] # Change the name of sheet ID '0' (the default first sheet on every # spreadsheet) requests.push({                 update_sheet_properties: {                   properties: { sheet_id: 0, title: 'New Sheet Name' },                   fields:     'title'                 }               }) # Find and replace text requests.push({                 find_replace: {                   find:        find,                   replacement: replacement,                   all_sheets:  true                 }               }) # Add additional requests (operations) ...  body = { requests: requests } result = service.batch_update_spreadsheet(spreadsheet_id, body, {}) find_replace_response = result.replies[1].find_replace puts "#{find_replace_response.occurrences_changed} replacements made."