这是一份写给运营人员的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  # 修改数值

修改了单元格的样式和数据后,可以打开表格看看效果。

参考:

运营的Python指南 - Python 操作Excel的更多相关文章

  1. 转 Python - openpyxl 读写操作Excel

    Python - openpyxl 读写操作Excel   openpyxl特点   openpyxl(可读写excel表)专门处理Excel2007及以上版本产生的xlsx文件,xls和xlsx之间 ...

  2. python用openpyxl操作excel

    python操作excel方法 1)自身有Win32 COM操作office但讲不清楚,可能不支持夸平台,linux是否能用不清楚,其他有专业处理模块,如下 2)xlrd:(读excel)表,xlrd ...

  3. python通过openpyxl操作excel

    python 对Excel操作常用的主要有xlwt.xlrd.openpyxl ,前者xlwt主要适合于对后缀为xls比较进行写入,而openpyxl主要是针对于Excel 2007 以上版本进行操作 ...

  4. 09 python学习笔记-操作excel(九)

    python操作excel使用xlrd.xlwt和xlutils模块,xlrd模块是读取excel的,xlwt模块是写excel的,xlutils是用来修改excel的.这几个模块可以使用pip安装, ...

  5. 用python库openpyxl操作excel,从源excel表中提取信息复制到目标excel表中

    现代生活中,我们很难不与excel表打交道,excel表有着易学易用的优点,只是当表中数据量很大,我们又需要从其他表册中复制粘贴一些数据(比如身份证号)的时候,我们会越来越倦怠,毕竟我们不是机器,没法 ...

  6. Python - openpyxl 读写操作Excel

    openpyxl特点   openpyxl(可读写excel表)专门处理Excel2007及以上版本产生的xlsx文件,xls和xlsx之间转换容易 注意:如果文字编码是“gb2312” 读取后就会显 ...

  7. python使用xlrd操作Excel文件

    一.xlrd读取Excel文件 用xlrd进行读取比较方便,流程和平常手动操作Excel一样,打开工作簿(Workbook),选择工作表(sheets),然后操作单元格(cell). 例子:要打开当前 ...

  8. python使用xlrd 操作Excel读写

    此文章非本人 一.安装xlrd模块 到python官网下载http://pypi.python.org/pypi/xlrd模块安装,前提是已经安装了python 环境. 二.使用介绍 1.导入模块 i ...

  9. Python使用openpyxl操作excel表格

    前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取 ht ...

随机推荐

  1. Flask基础(13)-->Flask扩展Flask-Script

    Flask基础(12)-->Flask扩展Flask-Script # 前提是安装了Flask-Script # 联网运行 pip install flask-script from flask ...

  2. 有了 CompletableFuture,使得异步编程没有那么难了!

    本文导读: 业务需求场景介绍 技术设计方案思考 Future 设计模式实战 CompletableFuture 模式实战 CompletableFuture 生产建议 CompletableFutur ...

  3. 微信小程序项目-你是什么垃圾?

    垃圾分类特别火也不知道北京什么时候也开始执行,看见之前上海市民被灵魂拷问了以后垃圾真的不知道如何丢了,作为程序员就做一个小程序造福人类吧. 效果图: 一.全局的app.json和app.wxss加入了 ...

  4. 【maven的使用】1maven的概念与配置

    maven是一个基于java平台的自动化构建工具.构建工具的发展由make->ant->maven->gradle其中gradle还在发展中,使用较少,学习难度比较大,所以目前占据主 ...

  5. SpringBoot-ElasticJob封装快速上手使用(分布式定时器)

    elastic-job-spring-boot qq交流群:812321371 1 简介 Elastic-Job是一个分布式调度解决方案,由两个相互独立的子项目Elastic-Job-Lite和Ela ...

  6. else块的用途

    除了在if...else...中使用,else块还可以在for循环.while循环以及try...except中使用. 在for循环中使用: my_list = ['a','b','c','d'] f ...

  7. TensorFlow2.0(六):Dataset

    .caret, .dropup > .btn > .caret { border-top-color: #000 !important; } .label { border: 1px so ...

  8. 31、vue-cli3引入封装svg图标

    svg图标放大不失真,png会出现失真现象. 一.方法一 1.在对应vue项目里添加插件 vue add svg-sprite 输入 Y 2.在执行 npm install svgo svgo-loa ...

  9. 新手学分布式-动态修改Nginx配置的一些想法

    本人是分布式的新手,在实际工作中遇到了需要动态修改nginx的需求,因此写下实现过程中的想法.Nginx功能强大且灵活,所以这些权当抛砖引玉,希望可以得到大家的讨论和指点.(具体代码在 https:/ ...

  10. 模拟telnet协议C语言客户端程序

    首先要了解telnet协议,一下两篇blog给了我初步的思路 https://www.cnblogs.com/liang-ling/p/5833489.html 这篇有比较基础的介绍 以及IAC命令含 ...