1 安装

pip install openpyxl
如果装不上,请指定安装源来安装
pip install -i https://pypi.douban.com/simple openpyxl
如果excel里面有图片(jpeg, png, bmp,…),需要安装图片处理模块
pip install pillow

2 excel的写

from openpyxl import Workbook
# 实例化对象
wb = Workbook()
# 创建工作簿,名字是上海,如果只写一个上海默认添加在最后一个工作簿中
wb1 = wb.create_sheet('上海')
# 创建工作簿,工作簿在第一个位置
wb2 = wb.create_sheet('广东',0)
# 获取当前工作中的工作簿
awb = wb.active
# 给工作不改名字
awb.title = "guangdong" # excel写数据,可以写表格的函数
# 向guangdong 的工作能力簿中写数据
# 向单元格中写数据
awb['A4'] = '广东美食' # 向第3行第4列的单元格中写数据
awb.cell(row=3,column=4,value="广东人吃福建人") # 追加写入整行数据
awb.append(['虾饺','凤爪','烧鹅']) # 可以循环的写入文件,从文件的第一行第一列开始写文件,每行写1,2,3,4
for i in range(10):
awb.append([1,2,3,4]) # 写表格的函数:
awb['A16']="=SUM(A6:A15)" # 保存文件
wb.save('城市.xlsx')

excel读数据

# 读文件
from openpyxl import load_workbook
# 实例化对象
wb = load_workbook('城市.xlsx',read_only=False,data_only=True)
# 获取所有工作簿的名字
# print(wb.sheetnames)
# 获取工作薄对象
wb1 = wb['guangdong'] # 如果单元格中有内容,但读出来是None,需要将文件打开手动保存一下,在读取,
# 在读取函数的单元格的时候,需要将data_only=True
a4= wb1["A4"].value
# None
a5 = wb1.cell(row=5,column=1).value
# 获取所有的行的数据,是一个生成器generator
row = wb1.rows
for r in row:
# r是每行的数据的对象,是元组的形式
print()
for l in r:
# l 是每个单元格的数据
print(l.value,end='\t') # 获取所有的列,是一个生成器
col = wb1.columns
for c in col:
print()
for i in c:
print(i.value,end='\t') # 共有多少行数据
print(wb1.max_row)
# 共有多少列数据
print(wb1.max_column)

在读表的时候需要注意的:

  

获取行和列

sheet.rows为生成器, 里面是每一行的数据,每一行又由一个tuple包裹。
sheet.columns类似,不过里面是每个tuple是每一列的单元格。读列的时候需要将read_only=False,或者不写,默认是False

在获取行或者列的时候,不能使用索引来取特定行的数据,因为sheel.rows是一个生成器,不过可以将生成器强转成列表,list(sheet.rows)[2] 这样就能取到第3行的数据了

在读有表格函数的表时:

读取的时候需要加上data_only=True这样读到B9返回的就是数字,如果不加这个参数,返回的将是公式本身'=AVERAGE(B2:B8)'

设置单元格风格--Style

先导入需要的类from openpyxl.styles import Font, colors, Alignment

分别可指定字体相关,颜色,和对齐方式。

字体:

bold_itatic_24_font = Font(name='等线', size=24, italic=True, color=colors.RED, bold=True)

sheet['A1'].font = bold_itatic_24_font

对齐方式:

也是直接使用cell的属性aligment,这里指定垂直居中和水平居中。除了center,还可以使用right、left等等参数

# 设置B1中的数据垂直居中和水平居中
sheet['B1'].alignment = Alignment(horizontal='center', vertical='center')

设置行高和列宽
有时候数据太长显示不完,就需要拉长拉高单元格。

# 第2行行高
sheet.row_dimensions[2].height = 40
# C列列宽
sheet.column_dimensions['C'].width = 30

合并和拆分单元格

所谓合并单元格,即以合并区域的左上角的那个单元格为基准,覆盖其他单元格使之称为一个大的单元格。
相反,拆分单元格后将这个大单元格的值返回到原来的左上角位置。

# 合并单元格, 往左上角写入数据即可
sheet.merge_cells('B1:G1') # 合并一行中的几个单元格
sheet.merge_cells('A1:C3') # 合并一个矩形区域中的单元格

合并后只可以往左上角写入数据,也就是区间中:左边的坐标。
如果这些要合并的单元格都有数据,只会保留左上角的数据,其他则丢弃。换句话说若合并前不是在左上角写入数据,合并后单元格中不会有数据。
以下是拆分单元格的代码。拆分后,值回到A1位置。

sheet.unmerge_cells('A1:C3')

通过excel表格的内容,向mysql数据库中导入数据:

import pymysql
from openpyxl import load_workbook db = pymysql.connect('127.0.0.1','root','','web')
cursor = db.cursor() insert_sql = '''insert into student values(%s,%s)'''
wd = load_workbook('学生.xlsx')
s = wd['学生']
rows = s.max_row
columns = s.max_column
data=[] for rx in range(1,rows+1):
for cx in range(1,columns+1):
data.append(str(s.cell(row=rx, column=cx).value)) cursor.execute(insert_sql,(data[0],data[1]))
data=[]
db.commit()

在做表操作的时候可能遇到错误:

1 文件在打开的状态,操作文件报的错误

save_workbook
archive = ZipFile(filename, 'w', ZIP_DEFLATED, allowZip64=True)
File "C:\Python36\lib\zipfile.py", line 1113, in __init__
self.fp = io.open(file, filemode)
PermissionError: [Errno 13] Permission denied: '城市.xlsx'

2 在读取列的数据时,需要将read_only=False 或者不写默认是False,

File "G:/python/exel/readfile.py", line 23, in <module>
col = wb1.columns
AttributeError: 'ReadOnlyWorksheet' object has no attribute 'columns'

python 操作excel openpyxl的更多相关文章

  1. python操作excel——openpyxl

    一.概述 python操作excel各个库对比:https://www.cnblogs.com/paul-liang/p/9187503.html 官方文档:https://openpyxl.read ...

  2. python操作excel (openpyxl)

    最近看到好几次群里有人问xlwt.wlrd的问题,怎么说呢,如果是office2007刚出来,大家用xlsx文件用不习惯,还可以理解,这都10年过去了喂,就算没有进化到office2016,还在用of ...

  3. Python操作excel(xlrd和xlwt)

    Python操作excel表格有很多支持的库,例如:xlrd.xlwt.openpyxl.win32com,下面介绍使用xlrd.xlwt和xlutils模块这三个库不需要其他的支持,在任何操作系统上 ...

  4. Python 利用Python操作excel表格之openyxl介绍Part2

    利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436) ## 绘图 c = LineChart()    ...

  5. Python 利用Python操作excel表格之openyxl介绍Part1

    利用Python操作excel表格之openyxl介绍 by:授客 QQ:1033553122 欢迎加入全国软件测试交流qq群(群号:7156436),免费获取以下性能监控工具(类似Nmon精简版) ...

  6. 运营的Python指南 - Python 操作Excel

    这是一份写给运营人员的Python指南.本文主要讲述如何使用Python操作Excel.完成Excel的创建,查询和修改操作. 相关代码请参考 https://github.com/RustFishe ...

  7. 用Python操作excel文档

    使用Python第三方库 这一节我们学习如何使用Python去操作Excel文档.如果大家有人不知道Excel的话,那么建议先学一学office办公基础.这里想要操作Excel,必须安装一个Pytho ...

  8. 使用Python操作Excel文档(一)

    Python | 使用Python操作Excel文档(一) 0 前言 在阅读本文之前,请确保您已满足或可能满足以下条件: 请确保您具备基本的Python编程能力. 请确保您会使用Excel. 请确保您 ...

  9. python操作excel表格(xlrd/xlwt)

    最近遇到一个情景,就是定期生成并发送服务器使用情况报表,按照不同维度统计,涉及python对excel的操作,上网搜罗了一番,大多大同小异,而且不太能满足需求,不过经过一番对源码的"研究&q ...

随机推荐

  1. C++ STL 之 vector

    #include <iostream> #include <vector> using namespace std; void printVector(vector<in ...

  2. SpringCloud之RabbitMQ安装

    本文介绍Linux以及MAC OS下的RabbitMQ安装及配置: 一.Linux环境下的RabbitMQ安装(CentOS) 1.安装ErLang Erlang(['ə:læŋ])是一种通用的面向并 ...

  3. 针对nginx应用场景的配置 知识整理

    本文为转载,原文链接 前言 原本想写整理一篇针对nginx应用场景的相应配置,但发现已经有人整理了,而且写得非常不错,特意转过来 概论 Nginx 是一款面向性能设计的 HTTP 服务器,能反向代理 ...

  4. 【python+selenium】截取某个元素

    一. selenium截图1.selenium提供了几个截取全屏的方法- get_screenshot_as_file(self, filename) --这个方法是获取当前window的截图,出现I ...

  5. Linux学习笔记(五)Linux常用命令:压缩命令

    Linux中最常见的5中压缩格式: zip gz bz2 tar.gz tar.bz2 一..zip压缩命令 压缩文件 zip [压缩文件名] [源文件] 例如: zip zijeak.zip zij ...

  6. Hadoop_17_MapRduce_案例2_实现用户手机流量统计(ReduceTask并行度控制)

    需求:1.统计每一个用户(手机号)所耗费的总上行流量.下行流量,总流量 1.数据如下:保存为.dat文件(因为以\t切分数据,文件格式必须合适) 1363157985066 13726230503 0 ...

  7. 2.06_Python网络爬虫_正则表达式

    一:爬虫的四个主要步骤 明确目标 (要知道你准备在哪个范围或者网站去搜索) 爬 (将所有的网站的内容全部爬下来) 取 (过滤和匹配我们需要的数据,去掉没用的数据) 处理数据(按照我们想要的方式存储和使 ...

  8. javascript typeof instanceof

    typeof用以获取一个变量或者表达式的类型,typeof一般只能返回如下几个结果: number,boolean,string,function(函数),object(NULL,数组,对象),und ...

  9. 开启aix SFTP日志 是否和链接SFTP有关呢

    1.修改SSH配置 vi /etc/ssh/sshd_config 在sftp配置处添加-l INFO -f AUTH Subsystem sftp /usr/lib64/ssh/sftp-serve ...

  10. okhttp拦截器之ConnectInterceptor解析

    主流程分析: 继续分析okhttp的拦截器,继上次分析了CacheInterceptor缓存拦截器之后,接下来到连接拦截器啦,如下: 打开看一下它的javadoc: 而整个它的实现不长,如下: 也就是 ...