Python-操作Excel

资产管理系统的第一版基本测试通过,需要把之前存放在excel里的数据倒入数据库,在加一个导出功能,我使用了 xlrd/xlwt 2个模块。使用简单,基本满足需求,就是在导入的时间格式转换上面有个小问题,下面会说下。

xlrd

一,安装

$sudo easy_install xlrd # windows 参考http://pypi.python.org/pypi/xlrd

二,简单使用

import xlrd
data = xlrd.open_workbook('demo.xls') # 打开demo.xls
data.sheet_names()        # 获取xls文件中所有sheet的名称
table = data.sheets()[0]  # 获取xls文件第一个工作表
table = data.sheet_by_index(0)        # 通过索引获取xls文件第0个sheet
table = data.sheet_by_name(u'Sheet1') # 通过工作表名获取 sheet
# 获取行数和列数
nrows = table.nrows
ncols = table.ncols
# 获取整行和整列的值(数组)
table.row_values(i)
table.col_values(i)
# 循环行,得到索引的列表
for rownum in range(1,table.nrows):
    print table.row_values(rownum)
# 获取单元格
cell_A1 = table.cell(0,0).value
cell_C4 = table.cell(2,3).value
# 分别使用行列索引
cell_A1 = table.row(0)[0].value
cell_A2 = table.col(1)[0].value

xlwt

一,安装

sudo easy_install xlwt  # windows 参考http://pypi.python.org/pypi/xlwt

二,简单使用

import xlwt
file = xlwt.Workbook()                # 注意这里的Workbook首字母是大写
table = file.add_sheet('sheet name')  # 新建一个sheet

table.write(0,0,'test')               # 写入数据table.write(行,列,value)

# 如果对一个单元格重复操作,会引发
# returns error:
# Exception: Attempt to overwrite cell:
# sheetname=u'sheet 1' rowx=0 colx=0
# 所以在打开时加cell_overwrite_ok=True解决

table = file.add_sheet('sheet name',cell_overwrite_ok=True)
file.save('demo.xls')     # 保存文件

# 另外,使用style
style = xlwt.XFStyle()    # 初始化样式
font = xlwt.Font()        # 为样式创建字体
font.name = 'Times New Roman'
font.bold = True
style.font = font         #为样式设置字体
table.write(0, 0, 'some bold Times text', style) # 使用样式

xlwt 允许单元格或者整行地设置格式。还可以添加链接以及公式。例子:http://scienceoss.com/write-excel-files-with-python-using-xlwt

Tips

Excel中存储的日期,在xlrd读入时候是一个fload对象,如2011-06-18直接读入显示的是40712.0。我们需要将其转换成int,其实这个数在在excel中是从1899/12/31从0开始累加的。下面我们需要转换这个日期:

date_float = table.row_values(1)[1]  #假设第一行第一列是日期
date_time = datetime.date.fromordinal(datetime.date(1899,12,31).toordinal()-1+int(date_float)).strftime("%Y-%m-%d")

上面使用了Python的datetime模块。欢迎交流,谢谢~

参考资料:

http://liluo.org/blog/2011/01/python-using-xlrd-xlwt-operate-excel/

http://blog.donews.com/limodou/archive/2005/07/08/459100.aspx

python3中用xlwt3写入excel
最近正好需要折腾 Python ,在使用xlwt3的时候出现了非常奇怪的问题,就是无论如何写都会出现一个奇怪的错误

Traceback (most recent call last):
  File "F:\temp\mycode\frist\frist.py", line 132, in <module>
    import xlwt3
  File "C:\Python33\lib\site-packages\xlwt3\__init__.py", line 3, in <module>
    from .workbook import Workbook
  File "C:\Python33\lib\site-packages\xlwt3\workbook.py", line 5, in <module>
    from .worksheet import Worksheet
  File "C:\Python33\lib\site-packages\xlwt3\worksheet.py", line 7, in <module>
    from .row import Row
  File "C:\Python33\lib\site-packages\xlwt3\row.py", line 8, in <module>
    from . import formula
  File "C:\Python33\lib\site-packages\xlwt3\formula.py", line 6, in <module>
    class Formula(object):
ValueError: '__init__' in __slots__ conflicts with class variable

代码如下
import xlwt3
wbk=xlwt3.Workbook()
sheet = wbk.add_sheet('sheet1',True)
sheet.write(2, 0, 1)
sheet.write(2, 1, 1)
wbk.save('ccc.xls')

百思不得骑姐,在土匪的帮助下删了一点东西终于可以正常使用了,汗死
打开Python33\Lib\site-packages\xlwt3\formula.py文件,将其中的
__slots__ = ["__init__",  "__s", "__parser", "__sheet_refs", "__xcall_refs"]
修改为
__slots__ = [ "__s", "__parser", "__sheet_refs", "__xcall_refs"]

即可。。。为什么这样,我也不知道,求大神指点。。。。

[Python]Python3.3 xlwt3 安装及使用报错解决办法汇总  


[Python]Python3.3 xlwt3 安装及使用报错解决办法汇总  


[Python]Python3.3 xlwt3 安装及使用报错解决办法汇总  


你可能感兴趣的:(Python-操作Excel)