python操做Excel的模块,网上提到的模块大体有:xlwings、xlrd、xlwt、openpyxl、pyxll等,他们提供的功能概括起来有两种:1、用python读写Excel文件,实际上就是读写有格式的文本文件,操做excel文件和操做text、csv文件没有区别,Excel文件只是用来储存数据。2、除了操做数据,还能够调整Excel文件的表格宽度、字体颜色等。另外须要提到的是用COM调用Excel的API操做Excel文档也是可行的,至关麻烦基本和VBA没有区别。python
xlwings的特点shell
# 导入xlwings模块,打开Excel程序,默认设置:程序可见,只打开不新建工做薄,屏幕更新关闭 import xlwings as xw app=xw.App(visible=True,add_book=False) app.display_alerts=False app.screen_updating=False # 文件位置:filepath,打开test文档,而后保存,关闭,结束程序 filepath=r'g:\Python Scripts\test.xlsx' wb=app.books.open(filepath) wb.save() wb.close() app.quit()
import xlwings as xw app=xw.App(visible=True,add_book=False) wb=app.books.add() wb.save(r'd:\test.xlsx') wb.close() app.quit()
import xlwings as xw app=xw.App(visible=True,add_book=False) wb=app.books.add() # wb就是新建的工做簿(workbook),下面则对wb的sheet1的A1单元格赋值 wb.sheets['sheet1'].range('A1').value='人生' wb.save(r'd:\test.xlsx') wb.close() app.quit()
打开已保存的test.xlsx,在sheet2的第二个单元格输入“苦短”,而后保存关闭,退出Excel程序 import xlwings as xw app=xw.App(visible=True,add_book=False) wb=app.books.open(r'd:\test.xlsx') # wb就是新建的工做簿(workbook),下面则对wb的sheet1的A1单元格赋值 wb.sheets['sheet1'].range('A1').value='苦短' wb.save() wb.close() app.quit()
掌握以上代码,已经彻底能够把Excel看成一个txt文本进行数据储存了,也能够读取Excel文件的数据,进行计算后,并将结果保存在Excel中。wb.=xw.books['工做簿的名字‘]
wb=xw.books.active
sht=xw.books['工做簿的名字‘].sheets['sheet的名字'] # 或者 wb=xw.books['工做簿的名字'] sht=wb.sheets[sheet的名字]
sht=xw.sheets.active
rng=xw.books['工做簿的名字‘].sheets['sheet的名字'] # 或者 sht=xw.books['工做簿的名字‘].sheets['sheet的名字'] rng=sht.range('A1')
# 注意Range首字母大写 rng=xw.Range('A1')
其中须要注意的是单元格的彻底引用路径是: # 第一个Excel程序的第一个工做薄的第一张sheet的第一个单元格 xw.apps[0].books[0].sheets[0].range('A1')
迅速引用单元格的方式是 sht=xw.books['名字'].sheets['名字']
# A1单元格 rng=sht[’A1'] # A1:B5单元格 rng=sht['A1:B5'] # 在第i+1行,第j+1列的单元格 # B1单元格 rng=sht[0,1] # A1:J10 rng=sht[:10,:10]
PS: 对于单元格也能够用表示行列的tuple进行引用数组
# A1单元格的引用 xw.Range(1,1) #A1:C3单元格的引用 xw.Range((1,1),(3,3))
# 注意".value“ sht.range('A1').value=1
# 将列表[1,2,3]储存在A1:C1中 sht.range('A1').value=[1,2,3] # 将列表[1,2,3]储存在A1:A3中 sht.range('A1').options(transpose=True).value=[1,2,3] # 将2x2表格,即二维数组,储存在A1:B2中,如第一行1,2,第二行3,4 sht.range('A1').options(expand='table')=[[1,2],[3,4]]
# 将A1的值,读取到a变量中 a=sht.range('A1').value
#将A1到A2的值,读取到a列表中 a=sht.range('A1:A2').value # 将第一行和第二行的数据按二维数组的方式读取 a=sht.range('A1:B2').value