openpyxl 读写excel2007使用笔记【感谢鱿鱼哥】
2011-03-28 18:03
489 查看
有一万年没来这儿写blog了,今天等着发版,抽空来写点东西吧。
python有很多模块都是用来操作excel的,比如xlrd,xlwt,pyExcelerator。用着很方便,但是问题是,只能支持到
excel2003。虽然一般的应用其实足够了,但是如果遇到了导出大量数据(超过65535条)的需求时,excel2003就不够用了。所以我就只好
去找一个能支持excel2007的模块。
google了一下,发现了这个openpyxl,不过网上也没什么中文的文档可以看,于是就自己琢磨琢磨。
I.安装
openpyxl的最新版本是1.5.0 下载地址 http://pypi.python.org/pypi/openpyxl/1.5.0
需求python的版本是2.6+ ,也就是说,如果centOS系统的机器想用,那得升级系统的python。。。
安装就是解压缩,然后cd到目录,然后
python setup.py install
你懂的~
II.读取excel2007文件
view plain
copy to clipboard
print
?
#-*- 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
view plain
copy to clipboard
print
?
写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上用,可能会有些问题。
本文只是简单的写了下使用的方法,之后格式超链接神马的之后再填上~
python有很多模块都是用来操作excel的,比如xlrd,xlwt,pyExcelerator。用着很方便,但是问题是,只能支持到
excel2003。虽然一般的应用其实足够了,但是如果遇到了导出大量数据(超过65535条)的需求时,excel2003就不够用了。所以我就只好
去找一个能支持excel2007的模块。
google了一下,发现了这个openpyxl,不过网上也没什么中文的文档可以看,于是就自己琢磨琢磨。
I.安装
openpyxl的最新版本是1.5.0 下载地址 http://pypi.python.org/pypi/openpyxl/1.5.0
需求python的版本是2.6+ ,也就是说,如果centOS系统的机器想用,那得升级系统的python。。。
安装就是解压缩,然后cd到目录,然后
python setup.py install
你懂的~
II.读取excel2007文件
view plain
copy to clipboard
?
#-*- 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'
)
#显示有多少张表
"Worksheet range(s):"
, wb.get_named_ranges()
"Worksheet name(s):"
, wb.get_sheet_names()
#取第一张表
sheetnames = wb.get_sheet_names()
ws = wb.get_sheet_by_name(sheetnames[0
])
#显示表名,表行数,表列数
"Work Sheet Titile:"
,ws.title
"Work Sheet Rows:"
,ws.get_highest_row()
"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
#打印字典数据个数
'Total:%d'
%len(data_dic)
#-*- 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
view plain
copy to clipboard
?
写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)
写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上用,可能会有些问题。
本文只是简单的写了下使用的方法,之后格式超链接神马的之后再填上~
相关文章推荐
- python中使用openpyxl 读写excel2007使用笔记
- openpyxl 读写excel2007使用笔记
- openpyxl 读写excel2007使用笔记
- 使用openpyxl读写Excel2007以及更高版本
- 使用poi读写excel2007中的所有sheet表——显示到jsp中(读),并且导出此excel表(写)
- Java6学习笔记66——使用BufferedReader类(流的读写)
- Unix学习笔记------文件IO------使用lseek设置文件当前读写偏移量(即:当前的读写位置)
- Python使用openpyxl读写excel文件
- 【Java学习笔记】使用BufferedReader类(流的读写)
- Python借助Openpyxl读写excel2007
- 使用POI读写word docx文件(笔记记录)
- # 转载:使用openpyxl读写excel文件
- 我的iphone开发学习笔记(九): 使用NSUserDefaults读写用户默认设置
- 第17章 使用BIOS进行键盘输入和磁盘读写 笔记2
- Python借助Openpyxl读写excel2007
- Python使用openpyxl读写excel文件
- SpringBoot笔记3---如何读写数据库之使用CrudRepository中提供的方法来读写数据库
- SpringBoot笔记6---如何读写数据库之使用JpaSpecificationExecutor读写数据库
- [Unity](笔记)使用litJson读写Json数据
- [Python笔记] 使用xlrd和xlwt进行简单的excel表格读写操作