Gspread 将电子表格导出到带格式的文件系统

问题描述 投票:0回答:2

我需要在文件系统上下载 Google 电子表格,我正在使用 Gspread 从 Google Drive 读取文件,效果很好。

我尝试导出为 CSV,但这当然会放弃格式。

    json_key = json.load(open('/googleDriveCredentials.json'))
    scope = ['https://spreadsheets.google.com/feeds']
    credentials = SignedJwtAssertionCredentials(json_key['client_email'], json_key['private_key'], scope)
    gc = gspread.authorize(credentials)
    wks = gc.openall()

    # processing first workbook
    spreadsheet = wks[1] 

    # Creating CSV file which doesn't preserve formatting
    for i, worksheet in enumerate(spreadsheet.worksheets()):
        filename = 'somefile' + str(i) + '.csv'
        with open(filename, 'wb') as f:
            writer = csv.writer(f)
            writer.writerows(worksheet.get_all_values())  

我想知道我是否可以做这样的事情

worksheet.export("/myFolder")
python django gspread
2个回答
1
投票

尝试导出到 .XLSX 文件。格式将被保留:

import gspread

gc = gspread.authorize(credentials)
sh = gc.open_by_url('your spreadsheet')
worksheet = sh.worksheet('your worksheet')
export_file = worksheet.export(format='xlsx')
f = open('filename.xlsx', 'wb')
f.write(export_file)
f.close()

0
投票

这是一个工作版本。

import gspread
from gspread.utils import ExportFormat

gc = gspread.authorize(credentials)
sh = gc.open_by_url('your spreadsheet')
worksheet = sh.worksheet('your worksheet')
export_file = workbook.export(format=ExportFormat.EXCEL)
f = open('filename.xlsx', 'wb')
f.write(export_file)
f.close()

您也可以在这里使用:

  • 导出格式.PDF
  • 导出格式.EXCEL
  • 导出格式.CSV
  • 导出格式.OPEN_OFFICE_SHEET
  • 导出格式.TSV
  • 导出格式.ZIPPED_HTML
© www.soinside.com 2019 - 2024. All rights reserved.