python如何操作excel 基础代码
一 基础操作
1打开excel表格并获取表格名称
wookbook = load_workbook(filename = 表格文件路径)
(注意只能打开存在的表格,不能用该方法创建一个新表格文件)
workbook.sheetnames # 获取表格文件内的sheet名称
2 通过sheet名称获取表格对象
sheet = workbook[sheet名称]
3 获取表格尺寸大小
sheet.dimensions
4获取表格内某个格子的数据
sheet = workbook.active 打开活跃的/唯一的表格
cell = sheet['A1'] 获取A1格子
value = cell.value 该格子的数据
5 获取某个格子的行数,列数,坐标
print(cell.row, cell.column, cell.coordinate)
6 可用行数和列数定位某个格子
cell = sheet.cell(row = 1,column =1)
7 获取一系列格子
cells = sheet['A1:A5']
cells = sheet['A']
8 获取一系列格子 (按行或者列获取)
for row in sheet.iter_row(min_row=2,max_row=3,min_col=1,max_col=2):
print(row) #获取一整行
for cell in row:
print(cell) (按行获取)
for col in sheet.iter_row(min_row=2,max_row=3,min_col=1,max_col=2):
print(col)
for cell in col:
print(cell) (按列获取) 9 迭代整个表格的所有行
for row in sheet.rows:
print(row) 10 向某个格子写入内容并保存
sheet['A1']='你好啊'
cell= sheet['a1'] ; cell.value = '你好啊'
11 用python列表数据插入一行
sheet.append(python列表) 会接在表格内已有数据后面
12 插入公式
直接赋值公式字符串
例 sheet['f1002']=AVERAGE(f2:f1001)
#查看openpyxl支持的公式
from openpyxl.utils import FORMULAE
print(FORMULAE)
13 插入一列
sheet.insert_cols(idx =2)
sheet.insert_cols(idx =2,amount=3)#插入3列
14 插入一行
sheet.insert_rows(idx =2)
sheet.insert_rows(idx =2,amount=3)#插入3行
15 删除行(列)
sheet.delete_rows(idx = 2)
sheet.delete_rows(idx=2,amount=3)
16 移动格子
#移动单元格(正整数为向下或向右,负整数为向左或向上)
sheet.move_range('C1:D4',rows=2,cols=-2)
17 创建新的sheet
workbook.create_sheet(sheet名称)
18 删除一个sheet
sheet = workbook['表格2']
workbook.remove(sheet)
19 复制一个sheet
sheet = workbook['表格1']
workbook.copy_worksheet(sheet)
20 修改表格名称
sheet = workbook.active
sheet.title = '表格1'
21 创建一个新的Excel表格文件
workbook = openpyxl.Workbook()
22 冻结窗格
sheet.freeze_panes = 'G2'
23 添加筛选
sheet.auto_filter.ref = sheet.dimensions # 对整张表进行筛选
二 颜色 ,字体,样式
网址 https://www.bilibili.com/video/BV197411f7Rp?p=9 from openpyxl.styles import Font
Font(name=字体名称,size=字体大小,bold=是否加粗,italic=是否斜体,color=字体颜色) 1 修改字体样式
font = Font(name='思源黑体 Regular',size=12,bold=True,italic=True,color='FF000')(rgb与hex转换)
cell.font = font
2 获取表格中字体的样式
cell.font.属性
cell = sheet['a2']
font = cell.font
print(font.name,font.size,font.bold,font.italic)
3 设置对其样式
Alignment(horizontal=水平对其模式,vertical=垂直对齐模式,text_rotation=旋转角度,wrap_text=是否自动换行)
cell= sheet['a1']
alignment =Alignment(horizontal='center',vertical='center',text_rotation=45,wrap_text=True)
cell.alignment = alignment
4 设置边框样式
Side(style=边线样式,color=边线颜色)
Border(left=左边线样式,right=右边线样式,top=上边线样式,bottom=下边线样式)
例:
cell = sheet['a3']
Side1=Side(style='thin',color='ff000')
Side2=Side(style='dotted',color='ff000')
border = Border(left=side1,right=side1,top=side2,bottom=side2)
cell.border=border
python如何操作excel 基础代码的更多相关文章
- Python“文件操作”Excel篇(上)
大家好,我们今天来一起探索一下用Python怎么操作Excel文件.与word文件的操作库python-docx类似,Python也有专门的库为Excel文件的操作提供支持,这些库包括xlrd.xlw ...
- C#开发中使用Npoi操作excel实例代码
C#开发中使用Npoi操作excel实例代码 出处:西西整理 作者:西西 日期:2012/11/16 9:35:50 [大 中 小] 评论: 0 | 我要发表看法 Npoi 是什么? 1.整个Exce ...
- Python读写操作Excel模块_xlrd_xlwt_xlutils
Python 读写操作Excel -- 安装第三方库(xlrd.xlwt.xlutils.openpyxl) 如果仅仅是要以表单形式保存数据,可以借助 CSV 格式(一种以逗号分隔的表格数据格式)进行 ...
- Python Pandas操作Excel
Python Pandas操作Excel 前情提要 ☟ 本章使用的 Python3.6 Pandas==0.25.3 项目中需要用到excel的文件字段太多 考虑到后续字段命名的变动以及中文/英文/日 ...
- Python之操作Excel、异常处理、网络编程
知识补充: 1.falsk模块中一些方法总结 import flask from flask import request,jsonify server = flask.Flask(__name__) ...
- Python - 常规操作Excel - 第二十六天
前言 作为一名资深程序员,通过代码熟练操作Excel是必不可少的技能,本章主要讲解Python通过openpyxl第三方库(官方文件说明)对Excel进行操作,使Excel程序化操作更为简单快捷. o ...
- Python 读写操作Excel —— 安装第三方库(xlrd、xlwt、xlutils、openpyxl)
数据处理是 Python 的一大应用场景,而 Excel 则是最流行的数据处理软件.因此用 Python 进行数据相关的工作时,难免要和 Excel 打交道. 如果仅仅是要以表单形式保存数据,可以借助 ...
- python中操作excel数据
python操作excel,python有提供库 本文介绍openpyxl,他只支持新型的excell( xlsx)格式,读取速度还可以 1.安装 pip install openpyxl 2.使用 ...
- python简单操作excel
python操作excel 写入excel # 写入excel import xlwt # 创建xls对象 wb = xlwt.Workbook() # 新增两个表单页(sheet1) sh1 = w ...
随机推荐
- IPv4地址表示法详解
在TCP/IP协议中,IP地址是一个最基本的概念,本文就来参考<计算机网络>谢希仁 这本书,总结一下IPv4地址表示法的发展阶段,做个读书笔记. IP地址的编址方法共经过了三个历史阶段: ...
- koa2框架介绍
koa2框架介绍 1.koa2介绍:是当前最流行的node.js的框架,koa2是由express原来的人打造的.他的体积很小,但是扩展性很强. 2.koa2优点和缺点: 2.1.优点: .抛弃了ca ...
- Symantec NBU :Unable to retrieve version of the server xxx.xxx.xxx
Symantec NetBackup 是赛门铁克收购的veritas公司的一款产品,该产品功能强大,据称堪称备份界的鼻祖. 其具体原理和备份方式可见:https://blog.51cto.com/s ...
- MySQL到底能有多少个字段
今天技术讨论群里 “一切随遇而安”同学看书时出现一个疑问,一个MySQL的表中到底可以有多少个字段?带着这个疑问,我们展开了探讨,也接着讨论了一个单字段长度的问题. 1. 官方文档说明 官方文档的内 ...
- spring boot项目打war包
1.如果有本地依赖,添加本地依赖到maven <!--lib目录下的jar包--> <dependency> <groupId>com.dm</groupId ...
- python win32com
要使用Python控制MS Word,您需要先安裝win32com套件,這個套件可以到 http://sourceforge.net/projects/pywin32/ 找到.本文假設您已經正確安裝w ...
- 高性能RabbitMQ
1,什么是RabbitMq RabbitMQ是实现了高级消息队列协议(AMQP)的开源消息代理软件(亦称面向消息的中间件).RabbitMQ服务器是用Erlang语言编写的,而集群和故障转移是构建在开 ...
- Springboot使用自定义注解实现简单参数加密解密(注解+HandlerMethodArgumentResolver)
前言 我黄汉三又回来了,快半年没更新博客了,这半年来的经历实属不易,疫情当头,本人实习的公司没有跟员工共患难, 直接辞掉了很多人.作为一个实习生,本人也被无情开除了.所以本人又得重新准备找工作了. 算 ...
- php基本数据类型解说
一.简介: php语言是弱类型语言,声明变量的时候不需要指定数据类型.但每个数值都是有数据类型的.PHP共有九种数据类型. php基本数据类型共有四种:boolean(布尔型),integer(整型) ...
- Java工程师技能点梳理
从个人技术积累的角度,来看看一名合格的Java工程师在面试时所需要的知识技能. 1.基本语法 这包括static.final.transient等关键字的作用,foreach循环的原理等等.今天面试我 ...