python使用openpyxl库读写Excel表格的方法(增删改查操作)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
python使⽤openpyxl库读写Excel表格的⽅法(增删改查操作)
⽬录
⼀、前⾔
⼆、安装openpyxl
三、openpyxl的使⽤
四、结束语
⼀、前⾔
嗨,⼤家好,我是新发。
最近需要做个⼩⼯具,可以通过python来读写Excel,实现增删改查操作。
以前⽤的是xlrd和xlwt这两个python库,今天我要讲的是openpyxl库,我觉得openpyxl⽐xlrd和xlwt更强⼤更好⽤,话不多说,开始吧。
⼆、安装openpyxl
可以直接通过命令⾏安装
pip install openpyxl
不过如果你下载了openpyxl,因为openpyxl还依赖了et_xmlfile库,所以你还得下载个et_xmlfile。
如果是⽤命令⾏pip install openpyxl,则会⾃动下载依赖。
安装完毕后,在python中执⾏import openpyxl如果没有报错,则说明安装成功了。
三、openpyxl的使⽤
1、创建Excel⽂件
演⽰代码:
import openpyxl
book = openpyxl.Workbook()
book.save(u'我的表格.xlsx')
运⾏效果如下,⽣成了⼀个excel表格。
2、加载已存在的Excel⽂件
上⾯已经创建了⼀个表格,我们可以直接加载它。
演⽰代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
# ...
book.close()
3、创建sheet
演⽰代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book.create_sheet('我的Sheet')
book.save(u'我的表格.xlsx')
book.close()
运⾏效果如下:
4、判断某个sheet是否存在
演⽰代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
if None != book[u'我的Sheet']:
print('我的Sheet 存在')
book.close()
运⾏结果:
我的Sheet 存在
5、遍历所有Sheet的名称
演⽰代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
for sheet_name in book.sheetnames:
print(sheet_name)
book.close()
运⾏结果:
Sheet
我的Sheet
6、写⼊单元格
演⽰代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
sheet.cell(1,1).value = 'name'
sheet.cell(2,1).value = '姓名'
sheet.cell(3,1).value = '林新发'
book.save(u'我的表格.xlsx')
book.close()
运⾏效果
7、获取单元格的各个属性值
为了演⽰,我在我名字那⾥加个批注:
演⽰代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx') sheet = book['Sheet']
cell = sheet.cell(3,1)
# 获取单元格的值
print('value:%s'%cell.value)
# 获取⾏号、列号
print('row: %d, col: %d'%(cell.row, cell.column)) # 获取列名
print('column_letter: %s'%cell.column_letter)
# 单元格的坐标
print('coordinate: %s'%cell.coordinate)
# 单元格数据格式,n: 数字,s:字符串,d: ⽇期print('data_type: %s'%cell.data_type)
# 单元格编码格式
print('encoding: %s'%cell.encoding)
# 单元格样式
print('style: %s'%cell.style)
# 单元格批注
print('comment: %s'%ment)
book.close()
运⾏结果:
value:林新发
row: 3, col: 1
column_letter: A
coordinate: A3
data_type: s
encoding: utf-8
style: 常规
comment: Comment: linxinfa:
多才多艺 by linxinfa
8、遍历单元格
为了演⽰,我加多⼀写数据:
⼀⾏⼀⾏遍历,演⽰代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
# ⼀⾏⼀⾏遍历
for one_row in sheet.rows:
for cell in one_row:
print(cell, cell.value)
book.close()
运⾏结果:
<Cell 'Sheet'.A1> name
<Cell 'Sheet'.B1> profession
<Cell 'Sheet'.C1> hobby
<Cell 'Sheet'.A2> 姓名
<Cell 'Sheet'.B2> 职业
<Cell 'Sheet'.C2> 爱好
<Cell 'Sheet'.A3> 林新发
<Cell 'Sheet'.B3> Unity3D游戏开发⼯程师
<Cell 'Sheet'.C3> 吉他、钢琴、画画、猫猫、写博客
⼀列⼀列遍历,演⽰代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
# ⼀列⼀列遍历
for one_col in sheet.columns:
for cell in one_col:
print(cell, cell.value)
book.close()
运⾏结果:
<Cell 'Sheet'.A1> name
<Cell 'Sheet'.A2> 姓名
<Cell 'Sheet'.A3> 林新发
<Cell 'Sheet'.B1> profession
<Cell 'Sheet'.B2> 职业
<Cell 'Sheet'.B3> Unity3D游戏开发⼯程师
<Cell 'Sheet'.C1> hobby
<Cell 'Sheet'.C2> 爱好
<Cell 'Sheet'.C3> 吉他、钢琴、画画、猫猫、写博客
9、最⼤⾏最⼤列
为了演⽰,再加点数据。
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
print('max_row: %d, max_column: %d'%(sheet.max_row, sheet.max_column)) book.close()
运⾏结果:
max_row: 4, max_column: 3
10、删除⾏或列
为了演⽰,我再加多写数据。
演⽰代码:
import openpyxl
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
# 删除第5⾏
sheet.delete_rows(5)
# 删除第4列
sheet.delete_cols(4)
book.save(u'我的表格.xlsx')
book.close()
运⾏效果:
11、设置字体
演⽰代码:
import openpyxl
from openpyxl.styles import Font
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
cell = sheet.cell(4,1)
cell.font = Font(name='微软雅⿊',size=18,color='00FFCC99',b=True,i=False) book.save(u'我的表格.xlsx')
book.close()
运⾏效果:
12、填充单元格颜⾊
填充颜⾊之前
演⽰代码:
import openpyxl
from openpyxl.styles import PatternFill
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
cell = sheet.cell(4,2)
# 设置填充⾊
cell.fill = PatternFill('solid',fgColor='FFBB00')
book.save(u'我的表格.xlsx')
book.close()
运⾏效果:
13、设置⾏⾼与列宽
为了演⽰,我先把⾏⾼和列宽改成这样:
演⽰代码:
import openpyxl
from openpyxl.utils import get_column_letter
book = openpyxl.load_workbook(u'我的表格.xlsx')
sheet = book['Sheet']
# 取第4⾏
row_4 = sheet.row_dimensions[4]
# 设置⾏⾼
row_4.height = 15
# 取第2列
col_2 = sheet.column_dimensions[get_column_letter(2)]
# 设置列宽
col_2.width = 40
book.save(u'我的表格.xlsx')
book.close()
执⾏效果:
注意,上⾯我⽤到了⼀个get_column_letter⽅法,因为column_dimensions需要的是字母参数,所以我们不能直接传2,通过get_column_letter(2)即可得到"B",也就是第2列。
如果要反过来,通过字母逆算出数字,则⽤column_index_from_string⽅法,例:
from openpyxl.utils import column_index_from_string
print(column_index_from_string('B'))
# 输出2
四、结束语
完毕。
博主是Unity3D游戏⼯程师,喜欢Unity的同学,不要忘记点击关注,如果有什么Unity相关的技术难题,也欢迎留⾔或私信~
到此这篇关于python使⽤openpyxl库读写Excel表格的⽅法(增删改查操作)的⽂章就介绍到这了,更多相关python读写Excel表格内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!。