有一万年没来这儿写blog了,今天等着发版,抽空来写点东西吧。html
python有不少模块都是用来操做excel的,好比xlrd,xlwt,pyExcelerator。用着很方便,可是问题是,只能支持到excel2003。虽然通常的应用其实足够了,可是若是遇到了导出大量数据(超过65535条)的需求时,excel2003就不够用了。因此我就只好去找一个能支持excel2007的模块。python
google了一下,发现了这个openpyxl,不过网上也没什么中文的文档能够看,因而就本身琢磨琢磨。数据库
I.安装api
openpyxl的最新版本是1.5.0 下载地址 http://pypi.python.org/pypi/openpyxl/1.5.0google
需求python的版本是2.6+ ,也就是说,若是centOS系统的机器想用,那得升级系统的python。。。spa
安装就是解压缩,而后cd到目录,而后.net
python setup.py installexcel
你懂的~orm
II.读取excel2007文件htm
[python] view plaincopy
#-*- coding:utf-8 -*
from openpyxl.reader.excel import load_workbook
import MySQLdb
import time
#开始时间
startTime = time.time()
#读取excel2007文件
wb = load_workbook(filename = r'empty_book.xlsx')
#显示有多少张表
print "Worksheet range(s):", wb.get_named_ranges()
print "Worksheet name(s):", wb.get_sheet_names()
#取第一张表
sheetnames = wb.get_sheet_names()
ws = wb.get_sheet_by_name(sheetnames[0])
#显示表名,表行数,表列数
print "Work Sheet Titile:",ws.title
print "Work Sheet Rows:",ws.get_highest_row()
print "Work Sheet Cols:",ws.get_highest_column()
# 创建存储数据的字典
data_dic = {}
#把数据存到字典中
for rx in range(ws.get_highest_row()):
temp_list = []
pid = ws.cell(row = rx,column = 0).value
w1 = ws.cell(row = rx,column = 1).value
w2 = ws.cell(row = rx,column = 2).value
w3 = ws.cell(row = rx,column = 3).value
w4 = ws.cell(row = rx,column = 4).value
temp_list = [w1,w2,w3,w4]
data_dic[pid] = temp_list
#打印字典数据个数
print 'Total:%d' %len(data_dic)
注意的是ws.cell()方法,支持的参数有两种,cell(coordinate=None, row=None, column=None)
coordinate坐标,eg ws.cell("B1")
row 和 column 是行和列 ,都是从0开始
还有,若是想取得格里的值,得用ws.cell("A1").value 取到,若是用过xlrd,由于写法差很少,可能就会忘记加value了。
III.写入excel2007
[python] view plaincopy
写excel2007
#-*- coding:utf-8 -*
import MySQLdb
import time
import sys
#workbook相关
from openpyxl.workbook import Workbook
#万恶的ExcelWriter,妹的封装好了不早说,封装了很强大的excel写的功能
from openpyxl.writer.excel import ExcelWriter
#一个eggache的数字转为列字母的方法
from openpyxl.cell import get_column_letter
#新建一个workbook
wb = Workbook()
#新建一个excelWriter
ew = ExcelWriter(workbook = wb)
#设置文件输出路径与名称
dest_filename = r'empty_book.xlsx'
#第一个sheet是ws
ws = wb.worksheets[0]
#设置ws的名称
ws.title = "range names"
#录入数据,注意col是数字转字母,而后须要限定%s(string型)当参数传到ws.cell()方法中去,records能够想象为一个从数据库里查询出来的数据集合
i=1
table = {}
for record in records:
for x in range(1,len(record)+1):
col = get_column_letter(x)
ws.cell('%s%s'%(col, i)).value = '%s' % (record[x-1])
i+=1
#又建了一个sheet,ws名字都没变,太省了。。。可是确实是一个新的sheet,不会影响以前那个sheet的东西
ws = wb.create_sheet()
ws.title = 'Pi'
ws.cell('F5').value = 3.14
#写文件
ew.save(filename = dest_filename)
注意的地方:
# col是用列号x为参数,调用了这个模块的get_column_letter方法算出来的字母,这个比较蛋疼。
col = get_column_letter(x)
#在为数据格赋值的时候,注意写的格式:要不会有各类不靠谱的问题出现(这个是用坐标的方式写的,其实用row ,col的方式可能没那么麻烦)
ws.cell('%s%s'%(col, i)).value = '%s' % (record[x-1])
关于该模块的API 能够查询官方文档 http://packages.python.org/openpyxl/api.html
整体来讲,这个模块仍是挺方便的,可是问题就是在对于python的版本有必定要求,若是在centOs上用,可能会有些问题。
本文只是简单的写了下使用的方法,以后格式超连接神马的以后再填上~
关于pyExcelerator的使用教学,给朋友作个广告 http://blog.csdn.net/suofiya2008/archive/2010/05/14/5589627.aspx