超详细讲解Python中openpyxl库

2024-03-04 20:12
文章标签 python 讲解 详细 openpyxl

本文主要是介绍超详细讲解Python中openpyxl库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1.创建和保存工作簿

1.1创建工作簿

1.2打开工作簿

1.3属性

1.4方法

2.工作表的创建删除和复制

2.1从工作簿获取工作表

2.2删除工作表

2.3创建工作表

2.4复制工作表

2.4.1修改工作表名字

2.4.2修改标签栏字体颜色

2.5属性

2.6方法

持续更新中。。。。。。。。。。


1.创建和保存工作簿

1.1创建工作簿

使用openpyxl没有必要先在系统中新建一个.xlsx,只需要引入Workbook这个类,接着开始调用它,并保存到指定位置。

工作簿 = openpyxl.Workbook("文件名称.xlsx")

工作簿.save(路径)

from openpyxl import Workbook 
wb = Workbook()#新建工作簿 
wb.save(r'C:\\Users\\ownWS\\Desktop\\newexcel.xlsx')

1.2打开工作簿

工作簿 = openpyxl.load_workbook("文件名称.xlsx")

工作表 = 工作簿['工作表名']

from openpyxl as vb 
wb = vb.load_workbook()#1.打开工作簿 
ws = wb['Sheet'] #2.指定工作表

1.3属性

属性

作用

active

获取当前活跃的Woeksheet

worksheets

以列表的形式返回所有的Worksheet(表格)

read_only

判断是否以read_only模式打开excel文档

encoding

获取文档的字符集编码

properties

获取文档的元数据,如标题、创建者、创建日期

sheetnames

获取工作簿中表(列表

1.4方法

方法

作用

工作簿.sheetnames

获取所有表格的名字

工作簿['工作表名']

通过表格名字获取Woeksheet对象

工作簿.active

获取活跃表格

remove

删除一个工作表对象

create_sheet

创建一个空的表格

copy_worksheet

在Workbook内拷贝表格

一个工作簿(workbook)在创建的时候同时至少也新建了一张工作表(worksheet)。可以通过Workbook.active()调用得到正在运行的工作表。

ws = wb.active()

注意:该函数调用工作表的索引(_active_sheet_index),默认是0.除非修改这个值,否则会使用该函数一直是在对第一张工作表进行操作。

2.工作表的创建删除和复制

2.1从工作簿获取工作表

import openpyxl as vb 
path = r'C:\Users\ownWS\Desktop\newexcel.xlsx' 
wb = vb.load_workbook(path) #显示所有工作表 
ws = wb.worksheets 
print(ws) 
for i in ws: print(i.title)#工作表名称

2.2删除工作表

wb.remove(worksheet)移除工作表

  • worksheet为工作表对象,而非工作表名称

删除工作表的步骤

1.指定工作表

2.删除

3.保存

import openpyxl as vbpath = r'C:\Users\ownWS\Desktop\newexcel.xlsx'
wb = vb.load_workbook(path)
#删除工作表
sheet2 = wb['Sheet2']
wb.remove(sheet2)#删除工作表对象
wb.save(path)

注意:在创建工作簿的时候就已经自动创建一个名叫“Sheet”的工作表,首字母是大写的,移除工作表时,要先找到工作表对象wb['Sheet'],再把它放进renmove函数中进行移除

2.3创建工作表

wb.create_sheet(title = None,index = None)新建一张表

  • title:工作表的名称,
  • index:工作表的位置,默认放在最后
ws1 = wb.create_sheet() #默认插在工作簿末尾
#or
ws2 = wb.create_sheet(0)#插入在工作簿的第一个位置
ws3 = wb.create_sheet('表1',0)

2.4复制工作表

import openpyxl as vbpath = r'C:\Users\ownWS\Desktop\newexcel.xlsx'
wb = vb.load_workbook(path)
#复制工作表
copy_sheet = wb.copy_worksheet(wb['new title'])
wb.save(path)

2.4.1修改工作表名字

在创建工作表的时候系统自动命名。按照序列依次命名(Sheet,Sheet1,Sheet2,...)。可以通过调用下面属性修改工作表的名称:

ws.title = "new title"

2.4.2修改标签栏字体颜色

标签栏的背景色默认为白色,可以通过提供RRGGBB颜色码改变标签栏的字体颜色:

ws.sheet_properties.tabColor = "1072BA"

2.5属性

属性

作用

title

工作表名称

dimensions

表格的大小,这里的大小是指含有数据的表格的大小,即:左上角的坐标;右下角的坐标

max_row

表格的最大行

min_row

表格的最小行

max_column

表格的最大列

min_column

表格的最小列

rows

按行获取单元格(Cell对象)-生成器 工作表.rows

columns

按列获取单元格(Cell对象)-生成器 工作表.columns

freeze_panes

冻结窗格 工作表.freeze_pannes = 'C3'

values

按行获取表格的内容(数据)-生成器

freeze_panes,参数比较特别,主要用于表格较大是冻结顶部的行或左边的列。

对于冻结的行,在用户滚动时,是始终可见的,可以设置为一个Cell对象或一个单元格坐标的字符串,单元格上面的行和左边的列将会冻结(单元格坐在的行和列不会被冻结)。

例如:

要冻结第一行,设置A2为freeze_panes,

要冻结第一列,设置B1为freeze_panes,

同时冻结第一行和第一列,设置B2为freeze_panes,

freeze_panes为None,表示不冻结任何列和行

2.6方法

方法

作用

iter_rows

按行获取所有单元格,内置属性有(min_row,max_row,min_col,max_col)

iter_columns

按列获取所有单元格

append

在表格末尾添加数据

merged_cells

合并多个单元格

unmerged_cells

移除合并的单元格

持续更新中。。。。。。。。。。

这篇关于超详细讲解Python中openpyxl库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/774312

相关文章

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

Python运行中频繁出现Restart提示的解决办法

《Python运行中频繁出现Restart提示的解决办法》在编程的世界里,遇到各种奇怪的问题是家常便饭,但是,当你的Python程序在运行过程中频繁出现“Restart”提示时,这可能不仅仅是令人头疼... 目录问题描述代码示例无限循环递归调用内存泄漏解决方案1. 检查代码逻辑无限循环递归调用内存泄漏2.

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

如何在Mac上安装并配置JDK环境变量详细步骤

《如何在Mac上安装并配置JDK环境变量详细步骤》:本文主要介绍如何在Mac上安装并配置JDK环境变量详细步骤,包括下载JDK、安装JDK、配置环境变量、验证JDK配置以及可选地设置PowerSh... 目录步骤 1:下载JDK步骤 2:安装JDK步骤 3:配置环境变量1. 编辑~/.zshrc(对于zsh

使用Python构建一个Hexo博客发布工具

《使用Python构建一个Hexo博客发布工具》虽然Hexo的命令行工具非常强大,但对于日常的博客撰写和发布过程,我总觉得缺少一个直观的图形界面来简化操作,下面我们就来看看如何使用Python构建一个... 目录引言Hexo博客系统简介设计需求技术选择代码实现主框架界面设计核心功能实现1. 发布文章2. 加

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

Python如何自动生成环境依赖包requirements

《Python如何自动生成环境依赖包requirements》:本文主要介绍Python如何自动生成环境依赖包requirements问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录生成当前 python 环境 安装的所有依赖包1、命令2、常见问题只生成当前 项目 的所有依赖包1、