Python幾個讀取Excel庫的介紹:
xlwings
可結合 VBA 實現對 Excel 編程,強大的數據輸入分析能力,同時擁有豐富的接口,結合 pandas/numpy/matplotlib 輕松應對 Excel 數據處理工作。
openpyxl
簡單易用,功能廣泛,單元格格式/圖片/表格/公式/篩選/批注/文件保護等等功能應有盡有,圖表功能是其一大亮點,缺點是對 VBA 支持的不夠好。
pandas
數據處理是 pandas 的立身之本,Excel 作為 pandas 輸入/輸出數據的容器。
win32com
從命名上就可以看出,這是一個處理 windows 應用的擴展,Excel 只是該庫能實現的一小部分功能。該庫還支持 office 的眾多操作。需要注意的是,該庫不單獨存在,可通過安裝 pypiwin32 或者 pywin32 獲取。
xlsxwriter
擁有豐富的特性,支持圖片/表格/圖表/篩選/格式/公式等,功能與openpyxl相似,優點是相比 openpyxl 還支持 VBA 文件導入,迷你圖等功能,缺點是不能打開/修改已有文件,意味着使用 xlsxwriter 需要從零開始。
DataNitro
作為插件內嵌到 Excel 中,可完全替代 VBA,在 Excel 中使用 python 腳本。既然被稱為 Excel 中的 python,協同其他 python 庫亦是小事一樁。然而,這是付費插件...
xlutils
基於 xlrd/xlwt,老牌 python 包,算是該領域的先驅,功能特點中規中矩,比較大的缺點是僅支持 xls 文件。
安裝
pip install xlutils
讀取
import xlrd
workbook = xlrd.open_workbook(r'C:\Users\thinkpad\Desktop\dd.xlsx')#打開excel文件
print('number:',workbook.nsheets)#有幾張表
print('name:',workbook.sheet_names())#['Sheet1', 'Sheet2', 'Sheet3']
worksheet=workbook.sheet_by_index(0)#取第一張表
print('table %s 共%s 行 %s列' %(worksheet.name,worksheet.nrows,worksheet.ncols))#table Sheet1 共4 行 2列
print('第2行第1列:',worksheet.cell_value(1,0))#第2行第1列: 馬雲
for s in workbook.sheets():
for r in range(s.nrows):
print(s.row(r))#[text:'馬雲', number:52.0]
寫入
import xlwt
wb = xlwt.Workbook()#創建一個excel文件
sh = wb.add_sheet('a test sheet')#創建一張表
sh.write(0,0,'武松')#第1行第1列寫入武松
sh.write(1,0,'魯智深')
sh.write(2,0,'林沖')
wb.save('example.xls')#保存
修改
from xlutils.copy import copy
from xlrd import open_workbook
rb = open_workbook('example.xls')
wb = copy(rb)#拷貝一份
s = wb.get_sheet(0)
s.write(0,1,'new data')
wb.save('example.xls')#保存