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