运营的Python指南 - Python 操作Excel
这是一份写给运营人员的Python指南。本文主要讲述如何使用Python操作Excel。完成Excel的创建,查询和修改操作。
相关代码请参考 https://github.com/RustFisher/python-playground
本文链接:https://www.rustfisher.com/2019/11/05/Python/Python-op-excel_openpyxl_use/
开发工具,环境
- PyCharm - 方便好用的IDE
- Python3
这里默认你的电脑上已经装有python3.x,环境变量已经配置好。
引入openpyxl
这里使用openpyxl库来操作Excel。类似的库还有xlrd。
penpyxl的基础使用方法请参见Python openpyxl 处理Excel使用指南。
pip install openpyxl
数据准备
假定数据来自百度指数,以常见的一些搜索指数为例。给后面的操作准备一些数据,把数据写入Excel中。
创建Workbook对象,获取到当前可用的表格(sheet)。
直接使用append方法把一行数据追加写入。最后调用Workbook的保存方法,存储数据。
def create_excel_demo(file_path):
"""
创建Excel文件,并写入数据
:param file_path: 目标文件路径
:return none
"""
wb = Workbook()
ws = wb.active
ws.title = '搜索指数概览'
ws.append(['关键词', '整体日均值', '移动日均值', '整体同比', '整体环比', '移动同比', '移动环比'])
ws.append(['excel', 27782, 18181, -0.11, -2, 0.21, 0.02])
ws.append(['python', 24267, 8204, 0.27, 0.06, 0.56, 0.01])
ws.append(['文案', 2411, 1690, 0.56, 0.33, 0.91, 0.46])
ws.append(['okr', 1928, 880, 0.38, 0.15, 0.29, 0.09])
ws.append(['kpi', 4212, 2784, 0.21, -0.19, 0.36, -0.22])
wb.save(file_path)
创建出来的表格,示例数据如下
| 关键词 | 整体日均值 | 移动日均值 | 整体同比 | 整体环比 | 移动同比 | 移动环比 |
|---|---|---|---|---|---|---|
| excel | 27782 | 18181 | -0.11 | -2 | 0.21 | 0.02 |
| python | 24267 | 8204 | 0.27 | 0.06 | 0.56 | 0.01 |
| ... |
读取数据
访问整个表格的数据
访问表格中所有的数据,并打印出来。
首先我们要知道表格中有数据的单元格的范围,使用sheet.max_row与sheet.max_column获取表格的行列数量。
def read_xlsx_basic(file_path):
"""
读取Excel的数据并打印出来
"""
wb = load_workbook(file_path)
st = wb.active
end_row = st.max_row + 1
end_column = st.max_column + 1
print(st.title, '有', end_row, '行', end_column, '列')
for row in range(1, end_row):
for col in range(1, end_column):
print('{:10}'.format(st.cell(row=row, column=col).value), end='')
print()
值得注意的是,单元格下标是从1开始的。如果使用了不当的下标,报错信息
ValueError: Row or column values must be at least 1
参考: https://stackoverflow.com/questions/34492322/how-to-scan-all-sheet-cells
修改表格
有了Excel表格后,我们可以修改表格的一些格式和数据。
st表示当前表。
调整列的宽度
用 column_dimensions 来获取列。例如column_dimensions['A']获取到的是第A列。
ord方法是将字符转换为ascii码。ord('A')得到65。
这里调整的是A列到G列的宽度。
for col in range(ord('A'), ord('G') + 1):
st.column_dimensions[chr(col)].width = 15
设置单元格格式
格式,比如字体大小,对齐模式,粗体斜体等。
字体
首先我们要拿到单元格cell,这里使用st.cell(row=1, column=col)来获取某一个格子。
Cell持有的font是不可修改的。不能使用如cell.font.size = 13这样的操作,会报异常。
copy方法是复制一个对象。这里复制的是font。
cell = st.cell(row=1, column=col)
font = copy(cell.font)
font.size = 13
font.bold = True
cell.font = font
对齐
对齐模式。使用alignment属性。
cell.alignment = Alignment(horizontal="center", vertical="center")
数据显示
操作Excel时,我们可以设置单元格数据显示的方式,比如常规,数值,货币,百分比等等。
这里使用的是number_format属性。
如果数据(value)是0.02,经过下面的设置后,Excel中显示的是2%。
cell.number_format = '0%'
修改数据
修改单元格的数值(value)。
修改数据首先要拿到那个单元格cell,然后对其value赋值。
st.cell(row=2, column=7).value = 0.42 # 修改数值
修改了单元格的样式和数据后,可以打开表格看看效果。
参考:
- https://stackoverflow.com/questions/12387212/openpyxl-setting-number-format
- https://stackoverflow.com/questions/30050716/how-to-put-two-decimals-in-cell-with-type-of-percent
运营的Python指南 - Python 操作Excel的更多相关文章
- 转 Python - openpyxl 读写操作Excel
Python - openpyxl 读写操作Excel openpyxl特点 openpyxl(可读写excel表)专门处理Excel2007及以上版本产生的xlsx文件,xls和xlsx之间 ...
- python用openpyxl操作excel
python操作excel方法 1)自身有Win32 COM操作office但讲不清楚,可能不支持夸平台,linux是否能用不清楚,其他有专业处理模块,如下 2)xlrd:(读excel)表,xlrd ...
- python通过openpyxl操作excel
python 对Excel操作常用的主要有xlwt.xlrd.openpyxl ,前者xlwt主要适合于对后缀为xls比较进行写入,而openpyxl主要是针对于Excel 2007 以上版本进行操作 ...
- 09 python学习笔记-操作excel(九)
python操作excel使用xlrd.xlwt和xlutils模块,xlrd模块是读取excel的,xlwt模块是写excel的,xlutils是用来修改excel的.这几个模块可以使用pip安装, ...
- 用python库openpyxl操作excel,从源excel表中提取信息复制到目标excel表中
现代生活中,我们很难不与excel表打交道,excel表有着易学易用的优点,只是当表中数据量很大,我们又需要从其他表册中复制粘贴一些数据(比如身份证号)的时候,我们会越来越倦怠,毕竟我们不是机器,没法 ...
- Python - openpyxl 读写操作Excel
openpyxl特点 openpyxl(可读写excel表)专门处理Excel2007及以上版本产生的xlsx文件,xls和xlsx之间转换容易 注意:如果文字编码是“gb2312” 读取后就会显 ...
- python使用xlrd操作Excel文件
一.xlrd读取Excel文件 用xlrd进行读取比较方便,流程和平常手动操作Excel一样,打开工作簿(Workbook),选择工作表(sheets),然后操作单元格(cell). 例子:要打开当前 ...
- python使用xlrd 操作Excel读写
此文章非本人 一.安装xlrd模块 到python官网下载http://pypi.python.org/pypi/xlrd模块安装,前提是已经安装了python 环境. 二.使用介绍 1.导入模块 i ...
- Python使用openpyxl操作excel表格
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取 ht ...
随机推荐
- mysql 事物四大特性和事物的四个隔离
1.事物四大特性(ACID) 原子性(atomicity):一个事务必须视为一个不可分割的最小工作单元,整个事务中的所有操作要么全部提交成功,要么全部失败回滚,对于一个事务来说,不可能只执行其中的一部 ...
- Scala XML
XML 直接在代码中使用 XML 字面量 val doc: Elem = <html><head><title>Test</title></hea ...
- .NET成人礼 | 还记得20年前一起拖过的控件吗?
本文是MVP Ediwang写的回忆一个80后的拖控件的感悟,与君共勉: 每一代人都有记忆里的味道.煤球炉.黑白电视机是属于父母的记忆.而“拖控件”式编程,启蒙了无数像我这样的80后(嗯,89也算80 ...
- 手把手带你体验Stream流
前言 只有光头才能变强. 文本已收录至我的GitHub仓库,欢迎Star:https://github.com/ZhongFuCheng3y/3y 上一篇讲解到了Lambda表达式的使用<最近学 ...
- Xshell、Xftp 5、6 解决“要继续使用此程序,您必须应用最新的更新或使用新版本”
今天打开Xshell.Xftp,突然弹出“要继续使用此程序,您必须应用最新的更新或使用新版本”. 后来经过一番搜索发现,XShell配置文件中写入了强制升级时间,这个版本是2017年12月27日发布的 ...
- java中List、Set和Map三个接口及其主要实现类
三个接口都在java.util包下 List与Set具有相似性,它们都是单列元素的集合,所以,它们有一个共同的父接口,叫Collection,Map没有继承Collection接口 1.List接口: ...
- JZOJ 3875 星球联盟
[问题描述] 在遥远的 S 星系中一共有 N 个星球,编号为 1…N.其中的一些星球决定组成联盟, 以方便相互间的交流. 但是,组成联盟的首要条件就是交通条件.初始时,在这 N 个星球间有 M 条太空 ...
- VMware workstation Windows 10虚拟机安装步骤
1. 在首页点击创建新的虚拟机 2. 选择典型,下一步 3.选择稍后安装操做系统,下一步. 4. 选择第一个Microsoft Windows,版本选择如图. 5. 选择安装位置,我放在D盘. 7. ...
- Spring Cloud Gateway的动态路由怎样做?集成Nacos实现很简单
一.说明 网关的核心概念就是路由配置和路由规则,而作为所有请求流量的入口,在实际生产环境中为了保证高可靠和高可用,是尽量要避免重启的,所以实现动态路由是非常有必要的:本文主要介绍 Spring Clo ...
- LeetCode初级算法--链表02:合并两个有序链表
LeetCode初级算法--链表02:合并两个有序链表 搜索微信公众号:'AI-ming3526'或者'计算机视觉这件小事' 获取更多算法.机器学习干货 csdn:https://blog.csdn. ...