python操作Excel的模块,网上提到的模块大致有:xlwings、xlrd、xlwt、openpyxl、pyxll等,他们提供的功能归纳起来有两种:一、用python读写Excel文件,实际上就是读写有格式的文本文件,操作excel文件和操作text、csv文件没有区别,Excel文件只是用来储存数据。二、除了操作数据,还可以调整Excel文件的表格宽度、字体颜色等。另外需要提到的是用COM调用Excel的API操作Excel文档也是可行的,相当麻烦基本和VBA没有区别。

xlwings的特色
- xlwings能够非常方便的读写Excel文件中的数据,并且能够进行单元格格式的修改
- 可以和matplotlib以及pandas无缝连接
- 可以调用Excel文件中VBA写好的程序,也可以让VBA调用用Python写的程序。
- 开源免费,一直在更新
基本操作

- 打开已保存的Excel文档
# 导入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() - 新建Excel文档,命名为test.xlsx,并保存在D盘。
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() - 在单元格输入值
新建test.xlsx,在sheet1的第一个单元格输入 “人生” ,然后保存关闭,退出Excel程序。
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 - 引用工作簿中的sheet
sht=xw.books['工作簿的名字‘].sheets['sheet的名字']
# 或者
wb=xw.books['工作簿的名字']
sht=wb.sheets[sheet的名字] - 引用活动sheet
sht=xw.sheets.active - 引用A1单元格
rng=xw.books['工作簿的名字‘].sheets['sheet的名字']
# 或者
sht=xw.books['工作簿的名字‘].sheets['sheet的名字']
rng=sht.range('A1') - 引用活动sheet上的单元格
# 注意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
参考资料:
xlwings官方文档
插上翅膀,让Excel飞起来——xlwings(二)
插上翅膀,让Excel飞起来——xlwings(三)
插上翅膀,让Excel飞起来——xlwings(四)
Excel中想实现使用Python代替VBA,请问应该怎么做?
python模块:win32com用法详解
python中使用xlrd、xlwt操作excel表格详解
网友评论
data=(('18083017212600301013','二维码收款',datetime.date(2018,9,23),Decimal('0.0030')),
('18083017212600301013','二维码收款',datetime.date(2018,9,24),Decimal('0.0500')))
wb2=xw.Book("F:/test.xlsx")
sht2=wb2.sheets['sheet1']
sht2.range("A1").value=data
wb2.save()
wb2.close()
ImportError: DLL load failed: 找不到指定的模块。
求解
1:实现读取(A1:A10)范围内单元格的值,如果值=1,则在(B1:B10)写入2。应该怎么写?
2:引用表格文件后就能对文件读写了吗?
#!/usr/bin/env python
# encoding: utf-8
# Created by Jackie at 2017/9/29
import pyodbc
import xlwings as xw
import time
def execute_odbc(sql_):
conn = pyodbc.connect('DSN=keen')
cursor = conn.cursor()
cursor.execute(sql_)
result1_filed = []
result2_data = cursor.fetchall()
for columns in cursor.description:
result1_filed.append(columns[0])
# print result1_filed
# print result2_data
cursor.close()
conn.close()
return result1_filed, result2_data
sql = """select * from vendor_rawdata.test limit 1000"""
field, data1 = execute_odbc(sql)
app = xw.App(visible=True, add_book=False)
wb = app.books.add()
sht = wb.sheets.active
sht[0, 0].value = field
sht[1, 0].value = data1 # 这一步不能写入,报错了 报错了
#以下是错误信息 pywintypes.com_error: (-2147352567, '\xb7\xa2\xc9\xfa\xd2\xe2\xcd\xe2\xa1\xa3', (0, None, None, None, 0, -2147352571), 1)
today = time.strftime('%Y-%m-%d %H\'%M\'%S', time.localtime())
path = path + '\\' + today + '.xlsx'
wb.save(path)
wb.close()
app.quit()
如果把这个元组用list()转换以下,转成一行列表,又可以把正行写进去
如果用fetchall() 生成的是元组构成的列表,写进去就会报错 折腾好久了,程序应该不会设计这么傻逼,不想写循环处理
>>> import xlwings as xw
>>> wb = xw.Book()
>>> xw.Range('A1').color = (255,255,255)
>>> xw.Range('A2').color
(255, 255, 255)
>>> xw.Range('A2').color = None
>>> xw.Range('A2').color is None
True
range对象,有一个color属性。在我的第二篇文章中有讲。字体好像目前还没有看到怎么修改。