欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python之如何復制excel模板并保留表格樣式

 更新時間:2023年06月21日 11:11:14   作者:天才少女愛迪生  
這篇文章主要介紹了python之如何復制excel模板并保留表格樣式問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

python復制excel模板并保留表格樣式

需求

按照模板生成excel報表。

本地有一個模板Excel表,是xlsx格式。

需要把傳過來的數(shù)據(jù),按照模板表生成新的寫入數(shù)據(jù)的報表。

情況

先嘗試了pandas,發(fā)現(xiàn)生成的新表并不會保留模板表中的樣式。查了各種處理excel的庫。

xlrd/xlwt/xlutils/win32/openpyxl等等,都有各種各樣問題。

結(jié)果

使用openpyxl讀取模板表,再保存,可以完全保留樣式復制模板excel,而且支持xlsx.

?import openpyxl
?df=openpyxl.load_workbook('costDay.xlsx')
?# wb=copy(df)
?df.save('de.xlsx')

其實還有個可以保留樣式的方式:

from xlrd import open_workbook
df=open_workbook('costDay.xlsx',formatting_info=True)

formatting_info的參數(shù)默認是False,默認不讀取表格樣式。如果設置True的話就會讀取樣式。

但很坑的一點是居然不支持xlsx,只支持xls。遂放棄。

python如何復制excel的表格內(nèi)容及格式

python向excel寫內(nèi)容時,格式如保復用的問題

如下圖

新寫入的數(shù)據(jù),要與第一列保持一致

直接寫數(shù)據(jù),效果是這樣的式的,顯然是不行。

# 定義一個函數(shù),把df寫入excel的指定位置
# start_line:excel寫入的起始行
# data_df:要寫入的數(shù)組
def write_excel(filepath,start_line, data_df):
    # 打開待寫入文件
    filePath =filepath
    tableAll = op.load_workbook(filePath)
    table1 = tableAll['Sheet1']
    for c in range(data_df.shape[1]):
        for r in range(data_df.shape[0]):
            table1.cell(row=start_line, column=c + 2).value = data_df.columns[c]
            data = data_df.iloc[r, c]
            table1.cell(row=start_line + r + 2, column=c + 2).value = data
            # 以第一列復制格式
            table1.cell(row=start_line + r + 2, column=c + 2).font = copy(table1.cell(row=start_line + r + 2, column=1).font)
            table1.cell(row=start_line + r + 2, column=c + 2).fill = copy(table1.cell(row=start_line + r + 2, column=1).fill)
            table1.cell(row=start_line + r + 2, column=c + 2).border = copy(table1.cell(row=start_line + r + 2, column=1).border)
            table1.cell(row=start_line + r + 2, column=c + 2).number_format = copy(table1.cell(row=start_line + r + 2, column=1).number_format)
            table1.cell(row=start_line + r + 2, column=c + 2).protection = copy(table1.cell(row=start_line + r + 2, column=1).protection)
            table1.cell(row=start_line + r + 2, column=c + 2).alignment = copy(table1.cell(row=start_line + r + 2, column=1).alignment)
    tableAll.save(filePath)

效果是這樣的

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論