Python对Excel的常用操作

F#函数派
• 阅读 2126

本文是Python对Excel常用操作的演示

测试环境:

Python 3.7
openpyxl 3.0.5
Windows 10 专业版(CPU:i5-8500 RAM:16GB)

使用到的Python包:

1.OS(内置,无需安装)
2.random(内置,无需安装)
3.openpyxl 安装:

pip3 install openpyxl==3.0.5
运行代码
# 1.解压'excel_oparetion.rar'后
# 2.
python3 excel_base_op.py
Excel在openpyxl中对应的的对象

工作簿(workbook): 一个 Excel 电子表格文档;
工作表(sheet): 每个工作簿可以包含多个表, 如: sheet1, sheet2等;
活动表(active sheet): 用户当前查看的表;
列(column): 列地址是从 A 开始的;
行(row): 行地址是从 1 开始的;
单元格(cell): 特定行和列的方格;

openpyxl的基础操作(建议一步一步跟着操作哦,虽然后边有有完整代码)

导包

import random
import openpyxl

读取Excel:
1.打开现有工作表,获取workbook对象

file_name = "练习.xlsx"
wb = openpyxl.load_workbook(file_name)

2.workbook的基本属性

# 获取表格中所有sheet的名字,返回一个列表
sheet_name_lis = wb.sheetnames
print("文件 %s, 拥有sheet的名字列表为:%s" % (file_name, sheet_name_lis))
# 文件 练习.xlsx, 拥有sheet的名字列表为:['Sheet1', 'Sheet2']

3.获取sheet对象

sheet_name_1 = wb.sheetnames[0]
sheet_1 = wb[sheet_name_1]

4.sheet的基本属性

print("%s最大列数:%s, 最大行数:%s" % (sheet_1.title,sheet_1.max_column, sheet_1.max_row))
# Sheet1最大列数:5, 最大行数:10

5.获取cell对象

cell_1_2 = sheet_1.cell(1, 2)

6.cell的基本属性

print("单元格%s, 值:%s, 横坐标:%s,纵坐标%s" % (
            cell_1_2.coordinate, cell_1_2.value, cell_1_2.row, cell_1_2.column
        ))
# 单元格B1, 值:我是B1, 横坐标:1,纵坐标2

7.多种方式访问cell

# 1.使用列访问单元格
# 单列
col_b = sheet_1['B']
print("表 %s 列B的值:%s" % (sheet_1.title, [cel.value for cel in col_b]))
# 表 Sheet1 列B的值:['我是B1', '我是B2', '我是B3', '我是B4', '我是B5', '我是B6', '我是B7', '我是B8', '我是B9', '我是B10']

# 多列
# col_range = sheet_1['C:D']
# 2.使用行访问单元格
# 单行
row_3 = sheet_1[3]
print("表 %s 行3的值:%s" % (sheet_1.title, [r.value for r in row_3]))
# 表 Sheet1 行3的值:['我是A3', '我是B3', '我是C3', '我是D3', '我是E3']

# 多行
# row_range = sheet_1[2:5]

二·写入Excel:

1.创建新的excel文件,当然你也可以在当前文件修改

# 注意Workbook首字母是大写
new_wb = openpyxl.Workbook()

2.创建新的sheet

# 获取当前sheet,默认第一个
new_sheet_1 = new_wb.active
# 可以重命名sheet, 默认“sheet”
new_sheet_1.title = "我是新sheet"
# 或者新创建一个sheet
# new_sheet_1 = new_wb.create_sheet("我是title", 0)

3.插入数据

# 1.设定单元格的值,三种方式
new_sheet_1['A2'] = "第一种"
new_sheet_1.cell(row=2, column=2).value = "第二种"
new_sheet_1.cell(row=2, column=3, value="第三种")
# 2.整行写
# 添加一行到当前sheet的最底部(即逐行追加从第一行开始) 必须是list,tuple,dict,range,generator类型的。
# 1,如果是list,将list从头到尾顺序添加。
# 2,如果是dict,按照相应的键添加相应的键值。
new_sheet_1.append([0, 1, 2, 3])
new_sheet_1.append({"A": "This is A", "C": "This is C"})
new_sheet_1.append({1: "This is A", 3: "This is C"})

# 使用列写入单元格
col_c = new_sheet_1['C']
for cel in col_c:
    cel.value = random.randint(1, 50)

col_range = new_sheet_1['C:D']
for _cel in col_range:
    for c in _cel:
        c.value = random.randint(1, 50)

# 使用行写入单元格
# row_10 = new_sheet_1[10]
# row_range = new_sheet_1[2:9]

4.保存(必须要保存!!)

new_wb.save("我是新表.xlsx")
# 如果报这个错,大概率是你还开着这个表,关掉即可
# PermissionError: [Errno 13] Permission denied: '我是新表.xlsx'

三·其他
1.创建sheet的副本

copy_sheet = new_wb.copy_worksheet()

2.设置cell的背景色(RRGGBB)

from openpyxl.styles import PatternFill
# 生成样式
green_fill = PatternFill(fgColor="AACF91", fill_type="solid")
orange_fill = PatternFill(fgColor="FFC125", fill_type="solid")
# 填充样式
new_sheet_1.cell(2, 2).fill = green_fill
new_sheet_1.cell(2, 3).fill = orange_fill
new_wb.save("我是新表.xlsx")

四.练习
根据 '练习.xlsx' 文件sheet2中的H列分组,将其中值为1的行填充在 该文件 新建的sheet,将值为2的行填充在 新文件。

五.演示的完整

import random
import openpyxl
from openpyxl.styles import PatternFill

file_name = "练习.xlsx"
wb = openpyxl.load_workbook(file_name)

# 获取表格中所有sheet的名字,返回一个列表
sheet_name_lis = wb.sheetnames
print("文件 %s, 拥有sheet的名字列表为:%s" % (file_name, sheet_name_lis))
# 文件 练习.xlsx, 拥有sheet的名字列表为:['Sheet1', 'Sheet2']

sheet_name_1 = wb.sheetnames[0]
sheet_1 = wb[sheet_name_1]

print("%s最大列数:%s, 最大行数:%s" % (sheet_1.title, sheet_1.max_column, sheet_1.max_row))
# Sheet1最大列数:5, 最大行数:10

cell_1_2 = sheet_1.cell(1, 2)
print("单元格%s, 值:%s, 横坐标:%s,纵坐标%s" % (
            cell_1_2.coordinate, cell_1_2.value, cell_1_2.row, cell_1_2.column
        ))
# 单元格B1, 值:我是B1, 横坐标:1,纵坐标2

# 1.使用列访问单元格
# 单列
col_b = sheet_1['B']
print("表 %s 列B的值:%s" % (sheet_1.title, [cel.value for cel in col_b]))
# 表 Sheet1 列B的值:['我是B1', '我是B2', '我是B3', '我是B4', '我是B5', '我是B6', '我是B7', '我是B8', '我是B9', '我是B10']

# 多列
# col_range = sheet_1['C:D']

# 2.使用行访问单元格
# 单行
row_3 = sheet_1[3]
print("表 %s 行3的值:%s" % (sheet_1.title, [r.value for r in row_3]))
# 表 Sheet1 行3的值:['我是A3', '我是B3', '我是C3', '我是D3', '我是E3']

# 多行
# row_range = sheet_1[2:5]


# 注意Workbook首字母是大写
new_wb = openpyxl.Workbook()

# 获取当前sheet,默认第一个
new_sheet_1 = new_wb.active
# 可以重命名sheet, 默认“sheet”
new_sheet_1.title = "我是新sheet"
# 或者新创建一个sheet
# new_sheet_1 = new_wb.create_sheet("我是title", 0)

# 1.设定单元格的值,三种方式
new_sheet_1['A2'] = "第一种"
new_sheet_1.cell(row=2, column=2).value = "第二种"
new_sheet_1.cell(row=2, column=3, value="第三种")
# 2.整行写
# 添加一行到当前sheet的最底部(即逐行追加从第一行开始) 必须是list,tuple,dict,range,generator类型的。
# 1,如果是list,将list从头到尾顺序添加。
# 2,如果是dict,按照相应的键添加相应的键值。
new_sheet_1.append([0, 1, 2, 3])
new_sheet_1.append({"A": "This is A", "C": "This is C"})
new_sheet_1.append({1: "This is A", 3: "This is C"})

# 使用列写入单元格
col_c = new_sheet_1['C']
for cel in col_c:
    cel.value = random.randint(1, 50)

col_range = new_sheet_1['C:D']
for _cel in col_range:
    for c in _cel:
        c.value = random.randint(1, 50)

# 使用行写入单元格
# 单行
# row_10 = new_sheet_1[10]
# 多行
# row_range = new_sheet_1[2:9]

new_wb.save("我是新表.xlsx")
# 如果报这个错,大概率是你还开着这个表,关掉即可
# PermissionError: [Errno 13] Permission denied: '我是新表.xlsx'

# 生成样式
green_fill = PatternFill(fgColor="AACF91", fill_type="solid")
orange_fill = PatternFill(fgColor="FFC125", fill_type="solid")
# 填充样式
new_sheet_1.cell(2, 2).fill = green_fill
new_sheet_1.cell(2, 3).fill = orange_fill
new_wb.save("我是新表.xlsx")
点赞
收藏
评论区
推荐文章
Python进阶者 Python进阶者
4年前
盘点JavaScript中那些进阶操作知识(上篇)
前言相信做网站对JavaScript再熟悉不过了,它是一门脚本语言,不同于Python的是,它是一门浏览器脚本语言,而Python则是服务器脚本语言,我们不光要会Python,还要会JavaScript,因为它对做网页方面是有很大作用的。1.进阶操作这里列举了一些小编以前经常用到的一些例子以及一些经验,由于篇幅受限,这里我将会把部分执行结果的输出直接输入
Karen110 Karen110
4年前
超全整理|Python 操作 Excel 库 xlwings 常用操作详解!
大家好,我是早起。在之前的文章中我们曾详细的讲解了如何使用openpyxl操作Excel,其实在Python中还有其他可以直接操作Excel文件的库,如xlwings、xlrd、xlwt等等,本文就将讲解另一个优秀的库xlwings开头还是想说一下,各个库之间没有明确的好坏之分,每个库都有其适合的应用场景,并且xlwings和openpyxl
Karen110 Karen110
4年前
​一篇文章总结一下Python库中关于时间的常见操作
前言本次来总结一下关于Python时间的相关操作,有一个有趣的问题。如果你的业务用不到时间相关的操作,你的业务基本上会一直用不到。但是如果你的业务一旦用到了时间操作,你就会发现,淦,到处都是时间操作。。。所以思来想去,还是总结一下吧,本次会采用类型注解方式。time包importtime时间戳从1970年1月1日00:00:00标准时区诞生到现在
Stella981 Stella981
4年前
Python 操作 excel
一、概述操作excel是程序员经常要遇到的场景。因为产品、运营的数据都是以这种格式存储。所以,当程序员拿到这些数据肯定要解析,甚至需要把结果输出成excel文件。下面就介绍如果用Python方面的读、写excel文件。二、openpyxlAPythonlibrarytoread/wr
Stella981 Stella981
4年前
Python 操作excel
python操作excel使用xlrd、xlwt和xlutils模块。xlrd模块是读取excel的,xlwt模块是写excel的,xlutils是用来修改excel的一、python 读取excelimportxlrdbookxlrd.open_workbook('all_stu.xls')打开一个excelsheetb
Stella981 Stella981
4年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Stella981 Stella981
4年前
Python操作Excel
前言:Python操作Excel使用openpyxl模块,python中有好几个与excel相关操作的模块。xlrd库:从excel中读取数据,支持xls、xlsx格式。xlwt库:对excel进行修改操作,不支持对xlsx格式的修改。xlutils库:在xlrd和xlwd中对一个已存在的文件进行修改。openpyxl库:
Stella981 Stella981
4年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Stella981 Stella981
4年前
Python异常捕获与处理
一、任务描述  本实验任务主要对Python异常进行一些基本操作,通过完成本实验任务,要求学生熟练掌握Python异常的基本操作。并对异常的基本操作进行整理并填写工作任务报告。二、任务目标1、掌握Python异常的捕获2、掌握Python异常的处理三、任务环境Ubuntu16.04、Python2.7
Wesley13 Wesley13
4年前
MongoDB 常用查询操作
!(https://oscimg.oschina.net/oscnet/up3b29d40cea7fe2de0c98cb9b4a1eae7d091.JPEG)MongoDB查询操作可实现大部分关系型数据库的常用查询操作,本文对MongoDB常用查询进行讲解。在阅读本文前,推荐先阅读《MongoDB安装及文档的基本操作》(http
Python进阶者 Python进阶者
1年前
有遇到过吗?同样的规则 Excel 中 比Python 结果大
大家好,我是Python进阶者。一、前言前几天在Python白银交流群【JethroShen】问了一个Python处理Excel数据读取的问题。问题如下:有遇到过吗?同样的规则Excel中比Python结果大?二、实现过程这里【瑜亮老师】和【论草莓如何成为
F#函数派
F#函数派
Lv1
我绕得过江山错落,绕不过你。
文章
7
粉丝
0
获赞
0