-
Notifications
You must be signed in to change notification settings - Fork 920
Expand file tree
/
Copy pathsheets_batch_update.py
More file actions
79 lines (65 loc) · 2.2 KB
/
sheets_batch_update.py
File metadata and controls
79 lines (65 loc) · 2.2 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
"""
Copyright 2022 Google LLC
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
"""
# [START sheets_batch_update]
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")
# [END sheets_batch_update]