Python對Excel的操作


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')#保存


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM