config-generator/google_drive/google_sheet.py

97 lines
5.0 KiB
Python

#!/usr/bin/env python
# coding:utf-8
import gspread
from gspread import Worksheet
from oauth2client.service_account import ServiceAccountCredentials
GoogleDrive = {
"type": "service_account",
"project_id": "quickstart-1616645350080",
"private_key_id": "c27137e7a9bcb56debff4266d7f5e0b75d84e514",
"private_key": "-----BEGIN PRIVATE KEY-----\nMIIEvQIBADANBgkqhkiG9w0BAQEFAASCBKcwggSjAgEAAoIBAQClKVOarC1QskWD\nHxoS/S/Gah0oge71Fd4jDLOAU7cqOWY5/gPzHysBKCoA+Hrq/LE/SzzwFnqfoZTJ\n7RsokQB07iRyipjv6cm1tfZvguA95LVEAgAcpbsIYa/3gDeZ1QvP6ntTlUMCUdza\nP4l/hl3U9ZNqLAa3axKGxeJug6845BgG3fe1gF12ukyqHecUO9Ys5lUB5HsGv32c\nsIezTPFnNRmXyTSPTC4ufeU8tUhF6D+B5/jnSk+Lt7qjHzVBhyHnx7Aa1hYI2KoX\nn5Pp2hD8vaJR6FxMN1S3YP1DQnsjavU/p/wkG0cca/MkVjDc4Wst+00KDmDQb/sY\ndCBw/5RNAgMBAAECggEADFPC0TMTqMe9h3VdUViDZdhKt9jG2JUawNv0U9orvCOP\nnTl32wATCiGQzQS+y+YzZol7kWHkIiEBxXaEhekYsyGJJ+FvW8zDyOO9coI+sW/u\nFZbeokS+ang8FYmE3N75ZDnYnZrw5u3sQX/nh9SkET6JE64YjD0aI2QGq//5JpJF\nBOWFcmRq+oC4b2MmxjbYYfASz9SioyGPmDM9pnj0qAsooh8lbNYG2ot+SXUmQ5G7\n9jcAXAQA/qhboPEWWZr2bRSHum1s7Tnp0nuVR6gPQ48THCyp+ozyZ51ggg7a+KIY\nqWK59VdzZHKadrMqrANDkZyFk8g4WEYOFbcoroOEsQKBgQDOKIVig9m66BoD8l/u\nuEVnPLueOabKdsavwOcTRhIAOmXYiA0Tjntt2UgFMO+yi4LZujRnB0SHv/j6+UPV\nM6+AOdMUOThto9HhWB2CWg+F1U4eYD064GPllC3uiL/hNAy5OdNrtseR6tlQAG+f\nbARm1GqFk9vVHVyTlpWAULfPxQKBgQDNF3EwUkoPV0wALMKX6V4NjYQx6CsjbN7V\ndbBKBgt+OEEt/yE9L9dwuf2mN7YA37zZUFNfeZUnTNAH2EsmInI6wlewvUK7b9eZ\n3FmZcFHV4hlqE8A2vJwk0U42nJuC9dP5bTL8ZFst9qtRdFwlnrZ3rZXzVEtmBKVt\npIDLAZMy6QKBgQCUx/ejZmZ/FjyYNpZ3UPN9kv4QLakqmte/RWc+qKYbFgokX+OY\nBo8bcuEgJfYHE9omSdTBuiQCGFCWx8flmPyCfLjR8o2/yqeQiqgZR+fF/W/4ShpG\nYGSX7f3MFVLtM0QvdQUYynty2ltk+juUgT8X+xq5NkFDp4IFXXqddSOCxQKBgBa4\nLhXIR+QDK6wpSTVC6ORfdPGCYqT9/oFvFCRfHw7QdIf/51K75gXa1LqBGWxnXKhG\nObYt5dQAslrsHwcOcdEIjmZJ0QaqkRu+ST6yLp6e+WnC3lwx8KozdZKfLqsHSIAt\nFKTZCTDCTqArX7nbJyOC20WlZOTcRucqfgn/FqthAoGAe7aZTcUxLbtltXki9nym\nOWQ5WTbwSJukzG8BWtG6vuvJf+tyUvEcMXw5cnrem58FrDUqt1NAS+jso1d+aB9n\n+DulSAgaec/8kYcAnx2EnDQlXceB94FOsjfKD/j2T7ONteieGLYleliXVdhWu/ay\nTIljZsJu1Lnnq49cS0TLgIU=\n-----END PRIVATE KEY-----\n",
"client_email": "google-sheet@quickstart-1616645350080.iam.gserviceaccount.com",
"client_id": "105134275998904574352",
"auth_uri": "https://accounts.google.com/o/oauth2/auth",
"token_uri": "https://oauth2.googleapis.com/token",
"auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
"client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/google-sheet%40quickstart-1616645350080.iam.gserviceaccount.com"
}
google_drive_auth_scope = [
'https://www.googleapis.com/auth/drive',
'https://www.googleapis.com/auth/drive.file'
]
def singleton(cls):
_instance = {}
def inner():
if cls not in _instance:
_instance[cls] = cls()
return _instance[cls]
return inner
@singleton
class GoogleSheetHelper:
def __init__(self):
cred = ServiceAccountCredentials.from_json_keyfile_dict(GoogleDrive, google_drive_auth_scope)
self.googleDriveClient = gspread.authorize(cred)
self.sheet_dict = {}
def open_sheet_file(self, sheet_file_name):
if sheet_file_name in self.sheet_dict:
return self.sheet_dict[sheet_file_name]
else:
spread_sheet = self.googleDriveClient.open(sheet_file_name)
self.sheet_dict[sheet_file_name] = spread_sheet
return spread_sheet
def get_sheet_table(self, sheet_file_name, sheet_table_name) -> Worksheet:
try:
spread_sheet = self.open_sheet_file(sheet_file_name)
return spread_sheet.worksheet(sheet_table_name)
except Exception as e:
print(e)
return None
def get_or_create_sheet_table(self, sheet_file_name, sheet_table_name, row_count=1, col_count=1) -> Worksheet:
spread_sheet = self.open_sheet_file(sheet_file_name)
try:
return spread_sheet.worksheet(sheet_table_name), False
except:
return spread_sheet.add_worksheet(sheet_table_name, row_count, col_count), True
def get_sheet_row(self, sheet: Worksheet, row):
if sheet is None:
print('传入参数sheet异常 sheet is None')
return
if row < 0:
print(f'传入参数row异常 row={row}')
return
return sheet.row_values(row)
def sheet_append_row(self, sheet: Worksheet, value):
if sheet is None:
print('传入参数sheet is None')
return
sheet.append_row(value, value_input_option='USER_ENTERED')
def sheet_update_cells_value(self, sheet: Worksheet, cell_range, values):
if sheet is None:
print('传入参数sheet is None')
return
for i, cell in enumerate(cell_range):
cell.value = values[i]
sheet.update_cells(cell_range)
def sheet_update_cell_value(self, sheet: Worksheet, row, col, value):
if sheet is None:
print('传入参数sheet is None')
return
sheet.update_cell(row, col, value)
if __name__ == '__main__':
pass