Python3利用openpyxl读写Excel文件的方法实例


Posted in Python onFebruary 03, 2021

前言

Python中常用的操作Excel的三方包有xlrd,xlwt和openpyxl等,xlrd支持读取.xls和.xlsx格式的Excel文件,只支持读取,不支持写入。xlwt只支持写入.xls格式的文件,不支持读取。

openpyxl不支持.xls格式,但是支持.xlsx格式的读取写入,并且支持写入公式等。

原始数据文件apis.xlsx内容:

name method url data json result
get接口 get https://httpbin.org/get?a=1&b=2
post表单接口 post https://httpbin.org/post {name: Kevin,age:1}
post-json接口 post https://httpbin.org/post {name: Kevin,age: 21}

读取数据

读取所有数据

import openpyxl

# 打开excel
excel = openpyxl.load_workbook('apis.xlsx') # 有路径应带上路径
# 使用指定工作表
sheet = excel.active # 当前激活的工作表
# sheet = excel.get_sheet_by_name('Sheet1')
# 读取所有数据
print(list(sheet.values)) # sheet.values 生成器
print(sheet.max_column) # 最大列数
print(sheet.max_row) # 最大行数

显示结果:

[('name', 'method', 'url', 'headers', 'data', 'json', 'result'), ('get接口', 'get', 'https://httpbin.org/get?a=1&b=2', None, None, None, None), ('post表单接口', 'post', 'https://httpbin.org/post', 'cookie: token=123', '{name: Kevin,age: 21}', None, None), ('post-json接口', 'post', 'https://httpbin.org/post', None, None, '{name: Kevin,age: 21}', None)]
7
4

按行读取

代码接上例

...
# 按行读取
for row in sheet.iter_rows(min_row=1, min_col=1, max_col=3, max_row=3): 
 print(row)
# 读取标题行
for row in sheet.iter_rows(max_row=1):
 title_row = [cell.value for cell in row]
print(title_row)
# 读取标题行以外数据
for row in sheet.iter_rows(min_row=2):
 row_data = [cell.value for cell in row]
 print(row_data)

打印结果:

(<Cell 'Sheet1'.A1>, <Cell 'Sheet1'.B1>, <Cell 'Sheet1'.C1>)
(<Cell 'Sheet1'.A2>, <Cell 'Sheet1'.B2>, <Cell 'Sheet1'.C2>)
(<Cell 'Sheet1'.A3>, <Cell 'Sheet1'.B3>, <Cell 'Sheet1'.C3>)
['name', 'method', 'url', 'headers', 'data', 'json', 'result']
['get接口', 'get', 'https://httpbin.org/get?a=1&b=2', None, None, None, None]
['post表单接口', 'post', 'https://httpbin.org/post', 'cookie: token=123', '{name: Kevin,age: 21}', None, None]
['post-json接口', 'post', 'https://httpbin.org/post', None, None, '{name: Kevin,age: 21}', None]

读取单元格数据

代码接上例

...
# 读取单元格数据
print(sheet['A1'].value)
print(sheet.cell(1,1).value) # 索引从1开始

打印结果:

name
name

写入文件

代码接上例

# 写入单元格
sheet['F2'] = 'PASS'
result_col = title_row.index('result')+1 # 'result'所在的列号
sheet.cell(3, result_col).value = 'PASS'
# 整行写入
new_row = ['post-xml接口', 'post', 'https://httpbin.org/post']
sheet.append(new_row)
# 保存文件,也可覆盖原文件
excel.save("apis2.xlsx")

写入结果:

name method url data json result
get接口 get https://httpbin.org/get?a=1&b=2 PASS
post表单接口 post https://httpbin.org/post {name: Kevin,age:1} PASS
post-json接口 post https://httpbin.org/post {name: Kevin,age: 21}
post-xml接口 post https://httpbin.org/post

更多操作可参考官方文档: https://openpyxl.readthedocs.io/en/stable/

总结

到此这篇关于Python3利用openpyxl读写Excel文件的文章就介绍到这了,更多相关Python3用openpyxl读写Excel文件内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python时间戳与时间字符串互相转换实例代码
Nov 28 Python
Python中的匿名函数使用简介
Apr 27 Python
Python判断文件和文件夹是否存在的方法
May 21 Python
Python循环语句中else的用法总结
Sep 11 Python
使用Django和Python创建Json response的方法
Mar 26 Python
Django如何开发简单的查询接口详解
May 17 Python
python3+PyQt5 使用三种不同的简便项窗口部件显示数据的方法
Jun 17 Python
Python FTP文件定时自动下载实现过程解析
Nov 12 Python
python实现俄罗斯方块游戏(改进版)
Mar 13 Python
Python中格式化字符串的四种实现
May 26 Python
Python rabbitMQ如何实现生产消费者模式
Aug 24 Python
Python实现生活常识解答机器人
Jun 28 Python
python之openpyxl模块的安装和基本用法(excel管理)
Feb 03 #Python
python中time.ctime()实例用法
Feb 03 #Python
python中Array和DataFrame相互转换的实例讲解
Feb 03 #Python
利用Python过滤相似文本的简单方法示例
Feb 03 #Python
python time.strptime格式化实例详解
Feb 03 #Python
Python字符串的15个基本操作(小结)
Feb 03 #Python
python调用百度AI接口实现人流量统计
Feb 03 #Python
You might like
深入了解php4(2)--重访过去
2006/10/09 PHP
PHP新手上路(三)
2006/10/09 PHP
php打造属于自己的MVC框架
2012/03/07 PHP
深入理解require与require_once与include以及include_once的区别
2013/06/05 PHP
使用Smarty 获取当前日期时间和格式化日期时间的方法详解
2013/06/18 PHP
PHP设计模式(四)原型模式Prototype实例详解【创建型】
2020/05/02 PHP
详解new function(){}和function(){}() 区别分析
2008/03/22 Javascript
Js 时间函数getYear()的使用问题探讨
2013/04/01 Javascript
Jquery多选框互相内容交换的实例代码
2013/07/04 Javascript
弹出最简单的模式化遮罩层的js代码
2013/12/04 Javascript
Ubuntu中搭建Nodejs开发环境过程分享
2014/06/01 NodeJs
jQuery点缩略图弹出层显示大图片
2015/02/13 Javascript
jQuery实现企业网站横幅焦点图切换功能实例
2015/04/30 Javascript
浅析JavaScript 调试方法和技巧
2015/10/22 Javascript
nodejs制作爬虫实现批量下载图片
2017/05/19 NodeJs
通俗易懂地解释JS中的闭包
2017/10/23 Javascript
微信小程序实现流程进度的图样式功能
2018/01/16 Javascript
浅析vue-router jquery和params传参(接收参数)$router $route的区别
2018/08/03 jQuery
ES6入门教程之变量的解构赋值详解
2019/04/13 Javascript
详解如何在Vue项目中发送jsonp请求
2019/10/25 Javascript
[33:17]OG vs VGJ.T 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
python 排序算法总结及实例详解
2016/09/28 Python
Python利用splinter实现浏览器自动化操作方法
2018/05/11 Python
对Python3 pyc 文件的使用详解
2019/02/16 Python
Python中生成一个指定长度的随机字符串实现示例
2019/11/06 Python
html5指南-7.geolocation结合google maps开发一个小的应用
2013/01/07 HTML / CSS
美国最好的保健品打折网店:Swanson
2017/08/04 全球购物
西班牙多品牌鞋店连锁店:Krack
2018/11/30 全球购物
The North Face北面德国官网:美国著名户外品牌
2018/12/12 全球购物
size?丹麦官网:英国伦敦的球鞋精品店
2019/04/15 全球购物
上班看电影检讨书
2014/02/12 职场文书
财务审计整改报告
2014/11/06 职场文书
详解Redis实现限流的三种方式
2021/04/27 Redis
教你怎么用Python实现多路径迷宫
2021/04/29 Python
python数字图像处理之图像的批量处理
2022/06/28 Python
springboot+rabbitmq实现智能家居实例详解
2022/07/23 Java/Android