Python-操作Excel
来源:互联网 发布:mac word文件丢失 编辑:程序博客网 时间:2024/04/30 15:26
资产管理系统的第一版基本测试通过,需要把之前存放在excel里的数据倒入数据库,在加一个导出功能,我使用了 xlrd/xlwt 2个模块。使用简单,基本满足需求,就是在导入的时间格式转换上面有个小问题,下面会说下。
xlrd
一,安装
$sudo easy_install xlrd # windows 参考http://pypi.python.org/pypi/xlrd
二,简单使用
import xlrddata = xlrd.open_workbook('demo.xls') # 打开demo.xlsdata.sheet_names() # 获取xls文件中所有sheet的名称table = data.sheets()[0] # 获取xls文件第一个工作表table = data.sheet_by_index(0) # 通过索引获取xls文件第0个sheettable = data.sheet_by_name(u'Sheet1') # 通过工作表名获取 sheet# 获取行数和列数nrows = table.nrowsncols = 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).valuecell_C4 = table.cell(2,3).value# 分别使用行列索引cell_A1 = table.row(0)[0].valuecell_A2 = table.col(1)[0].value
xlwt
一,安装
sudo easy_install xlwt # windows 参考http://pypi.python.org/pypi/xlwt
二,简单使用
import xlwtfile = xlwt.Workbook() # 注意这里的Workbook首字母是大写table = file.add_sheet('sheet name') # 新建一个sheettable.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') # 保存文件# 另外,使用stylestyle = xlwt.XFStyle() # 初始化样式font = xlwt.Font() # 为样式创建字体font.name = 'Times New Roman'font.bold = Truestyle.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
最近正好需要折腾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 安装及使用报错解决办法汇总
0 0
- Flask Excel python操作excel
- 使用python操作excel
- python 操作 excel
- python操作excel
- python操作excel
- python操作Excel word
- python操作Excel
- Python操作Excel
- python操作excel
- python 写Excel操作
- Python Excel操作
- python操作excel
- python 操作Excel
- python操作excel
- python操作excel
- Python操作Excel
- Python-操作Excel
- Python操作Excel
- Service和activity如何通讯
- php日期相关
- Lua 模拟类的操作
- Oracle Statistic 统计信息 小结
- 如何使用Git上传项目代码到代码服务器
- Python-操作Excel
- Python基础编程(九)魔法方法、属性和迭代器
- Ormlite开源数据库框架
- 12.3
- POJ 2329 (暴力+搜索bfs)
- textarea计算输入字符大小并限制输入
- 算法学习十八----寻找发帖水王
- leetcode Largest Rectangle in Histogram
- 3.1 创建线程执行器