Python操作Excel教程(图文教程,超详细)Python xlwings模块详解,

「作者主页」:士别三日wyx
「作者简介」:CSDN top100、阿里云博客专家、华为云享专家、网络安全领域优质创作者
「推荐专栏」:小白零基础《Python入门到精通》

在这里插入图片描述

xlwings模块详解

  • 1、快速入门
  • 1、打开Excel
  • 2、创建工作簿
    • 2.1、使用工作簿
    • 2.2、操作工作簿
  • 3、创建工作表
    • 3.1、使用工作表
    • 3.2、操作工作表
    • 3.3、删除工作表
  • 4、读写单元格
    • 4.1、选择单元格
    • 4.2、写入数据到单元格
    • 4.3、读取单元格的数据
    • 4.4、设置单元格样式
    • 4.4、删除单元格

xlwings 是用来「处理Excel」的Python第三方库,开源免费,一直在更新。

使用前需要「下载」、安装 xlwings 模块

【File】-【Settings】-【Progect:xxx】-【Python Interpreter】

在这里插入图片描述

然后「导入模块」,as是别名,方便后续调用

import xlwings as xw

xlwings

  • App:表示Excel程序
  • Book:表示工作簿
  • Sheet:表示工作表
  • Range:表示单元格

1、快速入门

import xlwings as xw# 1、打开Excel程序,处理过程可观
with xw.App(visible=True) as app:# 2、选择使用的工作簿book = app.books[0]# 3、选择使用的工作表sheet = book.sheets[0]# 4、选择单元格范围,设置背景颜色sheet.range('A1').color = '#ff0000'# 向单元格写入数据sheet.range('A2').value = 'hello Excel'# 5、保存工作簿book.save('myExcel.xlsx')

预期:文件保存到当前目录,打开后看到我们写入的内容。


1、打开Excel

使用 App() 打开Excel程序,一个App对应一个Excel实例。

为了防止僵尸进程,建议这样「启动」Excel( with 搭建上下文,会「自动释放」资源,无需手动close)

import xlwings as xwwith xw.App(visible=True) as app:print(app)

输出:

<App [excel] 5276>

提示:

  • 桌面下方的任务栏会有Excel的程序一闪而过,这是因为 with 会自动关闭Excel;
  • 如果 visible=False,则任务栏看不到变化(程序不可见);
  • 如果直接用 xw.App() 的方式打开Excel,则会在桌面打开Excel,并且不会关闭。
  • app.activate():活动Excel,将Excel程序放到桌面最前方。focus=True表示将鼠标焦点移动到Excel。

实例

import xlwings as xwwith xw.App(visible=True) as app:app.activate(True)

预期:Excel显示在桌面最前方(一闪而过)。


2、创建工作簿

在Excel中,「新建」一个工作簿,并返回工作簿对象Book,有三种创建方式:

  • xw.Book()
  • xw.books.add()
  • app.books.add()

实例

import xlwings as xwwith xw.App(visible=True) as app:print('自带一个工作簿:', app.books[0])book2 = xw.Book()print(book2)book3 = xw.books.add()print(book3)book4 = app.books.add()print(book4)print(app.books)

输出:

自带一个工作簿: <Book [工作簿1]>
<Book [工作簿2]>
<Book [工作簿3]>
<Book [工作簿4]>
Books([<Book [工作簿1]>, <Book [工作簿2]>, <Book [工作簿3]>, ...])

2.1、使用工作簿

1)「使用」指定的工作簿,根据工作簿的名字/索引/序号,并返回工作簿对象,有五种方式。
注意:() 根据 序号 选择,从1开始;[]根据 索引 选择,从0开始。

  • app.books (序号)
  • app.books [索引]
  • xw.books [索引]
  • xw.books (序号)
  • xw.Book (名字)

实例

import xlwings as xwwith xw.App(visible=True) as app:print(app.books)print(app.books(1))print(app.books[0])print(xw.books[0])print(xw.books(1))print(xw.Book('工作簿1'))

输出:

Books([<Book [工作簿1]>])
<Book [工作簿1]>
<Book [工作簿1]>
<Book [工作簿1]>
<Book [工作簿1]>
<Book [工作簿1]>

2)使用指定的工作簿,根据「文件路径」(用r字符串包裹路径),有三种方式

  • xw.Book( 路径 )
  • xw.books.open( 路径 )
  • app.books.open( 路径 )

实例

import xlwings as xwwith xw.App(visible=True) as app:print(xw.Book(r'E:\test.xlsx'))print(xw.books.open(r'E:\test.xlsx'))print(app.books.open(r'E:\test.xlsx'))print(app.books)

输出:

<Book [test.xlsx]>
<Book [test.xlsx]>
<Book [test.xlsx]>
Books([<Book [工作簿1]>, <Book [test.xlsx]>])

2.2、操作工作簿

  • book.name:返回工作簿的名字
  • book.sheets:返回工作簿的所有sheet页(列表)
  • book.app:返回工作簿所在的App对象(Excel程序)

实例

import xlwings as xwwith xw.App(visible=True) as app:book = app.books[0]print(book.name)print(book.sheets)print(book.app, app)print(book.selection)

输出:

工作簿1
Sheets([<Sheet [工作簿1]Sheet1>])
<App [excel] 18392> <App [excel] 18392>
<Range [工作簿1]Sheet1!$A$1>

  • book.save():保存工作簿,如果不指定路径,则保存到当前路径。

语法

book.save( path, password )

参数

  • path :(可选)文件保存路径
  • password :(可选)文件打开密码

实例

import xlwings as xwwith xw.App(visible=True) as app:book = app.books[0]book.save(r'E:/test1.xlsx', 123456)

预期:文件保存到E盘,打开需要「输入密码」


  • book.to_pdf():导出PDF,如果不指定路径,则保存到当前路径。

注意:Excel必须有「内容」,才能导出PDF,否则会报错

语法

book.to_pdf( path, include, exclude, show )

参数

  • path :(可选)PDF文件保存路径,默认当前目录
  • include :(可选)包含哪些工作表,单个工作表名 或 多个工作表名的列表
  • exclude :(可选)不包含哪些工作表,单个工作表名 或 多个工作表名的列表
  • show :(可选)创建后使用默认应用打开PDF,默认值False

实例

import xlwings as xwwith xw.App(visible=True) as app:book = app.books[0]book.sheets[0]['A1'].value = 'text'book.to_pdf(show=True)

预期:PDF文件保存到当前目录下,并「自动打开」


3、创建工作表

使用工作簿对象 Book 「创建」工作表,返回工作表对象 Sheet ,一个 Sheet 对应一个工作表,有两种创建方式:

  • app.books[0].sheets.add()
  • xw.books[0].sheets.add()

创建工作表时,可以「设置表名」。参数2中, after 表示插入到某个表后面, before 表示插入到某个表前面。

  • app.books[0].sheets.add('name1')
  • xw.books[0].sheets.add('name2')

实例

import xlwings as xwwith xw.App(visible=True) as app:app.books[0].sheets.add('name1')xw.books[0].sheets.add()print('所有工作表:', app.books[0].sheets)

输出:

所有工作表: Sheets([<Sheet [工作簿1]Sheet3>, <Sheet [工作簿1]name1>, <Sheet [工作簿1]Sheet1>])

3.1、使用工作表

通过工作簿对象 Book 「使用」指定的工作表,根据工作表的名字/索引/序号,并返回工作表对象 Sheet ,有六种方式:

  • app.books[0].sheets[0]
  • app.books[0].sheets(1)
  • app.books[0].sheets['Sheet1']
  • xw.books[0].sheets[0]
  • xw.books[0].sheets(1)
  • xw.books[0].sheets['Sheet1']

注意:() 根据 序号 选择,从1开始;[]根据 索引 选择,从0开始。

实例

import xlwings as xwwith xw.App(visible=True) as app:book = app.books[0]print(book.sheets[0])print(book.sheets(1))print(book.sheets['Sheet1'])wb = xw.books[0]print(wb.sheets[0])print(wb.sheets(1))print(wb.sheets['Sheet1'])print('工作表列表:', book.sheets)

输出:

<Sheet [工作簿1]Sheet1>
<Sheet [工作簿1]Sheet1>
<Sheet [工作簿1]Sheet1>
<Sheet [工作簿1]Sheet1>
<Sheet [工作簿1]Sheet1>
<Sheet [工作簿1]Sheet1>
工作表列表: Sheets([<Sheet [工作簿1]Sheet1>])

3.2、操作工作表

1)工作表名

  • app.books[0].sheets[0].name = 'sheetName':设置工作表名
  • app.books[0].sheets[0].name:获取工作表名
  • app.books[0].sheets[0].book:获取工作表所属的工作簿
  • app.books[0].sheets[0].index:获取工作表的索引(从1开始)

2)行高列宽

  • app.books[0].sheets[0].autofit():自适应行高列宽
  • app.books[0].sheets[0].autofit(axis='rows'):自适应行高
  • app.books[0].sheets[0].autofit(axis='columns'):自适应列宽

3)导出工作表(不指定路径,默认保存到当前目录)

  • app.books[0].sheets[0].to_html():导出 HTML
  • app.books[0].sheets[0].to_pdf():导出 PDF(内容不能为空)

4)复制工作表

  • app.books[0].sheets('sheetName').copy():复制工作表为副本
  • name:(可选,str)副本的名字
  • before:(可选,sheet对象)复制到哪个工作表之前
  • after:(可选,sheet对象)复制到哪个工作表之后

3.3、删除工作表

  • app.books[0].sheets[0].clear_contents():删除文本但保留样式
  • app.books[0].sheets[0].clear_formats():删除样式但保留文本
  • app.books[0].sheets[0].clear():删除文本和样式
  • app.books[0].sheets[0].delete():删除工作表

4、读写单元格

单元格不需要创建,选中单元格「范围」,然后读写即可,一个 Range 对应一个单元格。

4.1、选择单元格

按照范围、位置,选择单元格,并返回单元格对象,有多种方式。

1)按照A1表示法(例:选中A1到B3范围的单元格)

  • sheet.range('A1')
  • sheet.range('A1:B2')

2)按照坐标位置,坐标从左上角起始

  • sheet.range(1, 1)
  • sheet.range((1, 1), (3, 4))

3)切片方式选择范围

  • sheet['A1']
  • sheet['A1:B2']
  • sheet[0, 0]
  • sheet[0:1, 0:4]

4)按照单元格名字

  • sheet.range('a1_name')

实例

import xlwings as xwwith xw.App(visible=True) as app:book = app.books[0]sheet = book.sheets[0]range1 = sheet.range('A1')print(range1)range2 = sheet.range('A1:B2')print(range2)range3 = sheet.range(1, 1)print(range3)range4 = sheet.range((1, 1), (3, 4))print(range4)print(sheet['A1'])print(sheet['A1:B2'])print(sheet[0, 0])print(sheet[0:1, 0:4])

输出:

<Range [工作簿1]Sheet1!$A$1>
<Range [工作簿1]Sheet1!$A$1:$B$2>
<Range [工作簿1]Sheet1!$A$1>
<Range [工作簿1]Sheet1!$A$1:$D$3>
<Range [工作簿1]Sheet1!$A$1>
<Range [工作簿1]Sheet1!$A$1:$B$2>
<Range [工作簿1]Sheet1!$A$1>
<Range [工作簿1]Sheet1!$A$1:$D$1>

4.2、写入数据到单元格

向指定单元格中写入数据,数据可以是单个值一维列表二维列表

  • sheet.range('A1').value = 'hello Excel'
  • sheet.range('A2').value = [1, 2, 3]
  • sheet.range('A3').value = [[11, 22], [33, 44]]

写入效果参见下图

在这里插入图片描述

提示:已经有数据的单元格,再次写入,会覆盖原来的数据,常用来修改单元格数据。


4.3、读取单元格的数据

按照A1表示法,读取指定范围内单元格的数据,读出的数据可以是单个数据列表二维列表形式。

  • sheet.range('A1').value
  • sheet.range('A2:C2').value
  • sheet.range('A3:B4').value

我们将上一步写入的数据读出来,输出结果如下:

hello Excel
[1.0, 2.0, 3.0]
[[11.0, 22.0], [33.0, 44.0]]

4.4、设置单元格样式

1)背景颜色

  • sheet.range('A1:A2').color = '#FF0000':按照颜色代码设置颜色
  • sheet.range('B1').color = (255, 255, 0):按照颜色坐标设置颜色
  • sheet.range('A2').color = None:去除背景颜色
  • sheet.range('A2').color is None:判断背景颜色是否为空
  • sheet.range('B1').color:获取背景颜色

2)行高列宽

  • sheet.range('A1').row_height:获取行高
  • sheet.range('A1').column_width:获取列宽
  • sheet.range('A1').row_height = 20:设置行高
  • sheet.range('A1').column_width = 20:设置列宽
  • sheet.range('A1').rows.autofit():自适应行高
  • sheet.range('A1').columns.autofit():自适应列宽
  • sheet.range('A1').autofit():自适应行高列宽

3)合并单元格

  • sheet.range('A1:C1').merge():合并单元格
  • sheet.range('B1:C1').unmerge():取消合并
  • sheet.range('A1').merge_area:返回指定单元格的合并范围,如果没有合并,就返回单元格本身
  • sheet.range('A1').merge_cells:判断是否包含合并单元格(True包含;False不包含)

4)函数公式

  • sheet.range('D1').formula = '=SUM(A1:C1)':设置函数公式
  • sheet.range('D1').formula:获取函数公式

5)单元格名字

  • sheet.range('A1').name = 'a1_name':设置单元格名字
  • sheet.range('A1').name:获取单元格名字

6)复制粘贴

  • sheet.range('A1').copy():将单元格的内容复制到剪贴板
  • sheet.range('A2').paste():将剪贴板的内容复制到单元格

4.4、删除单元格

删除指定范围的单元格、数据、样式

  • sheet.range('A1').clear_contents():删除数据但保留样式
  • sheet.range('A2').clear_formats():删除样式但保留数据
  • sheet.range('A3').clear():删除数据和样式
  • sheet.range('A1').delete():删除单元格

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/67226.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【css】z-index与层叠上下文

z-index属性用来设置元素的堆叠顺序&#xff0c;使用z-index有一个大的前提&#xff1a;z-index所作用元素的样式列表中必须有position属性并且属性值为absolute、relative或fixed中的一个&#xff0c;否则z-index无效。 层叠上下文 MDN讲解 我们给元素设置的z-index都是有一…

面试中的时间管理:如何在有限时间内展示最大价值

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

SVN 集中式版本管理平台

1. SVN 命令行工具下载地址 https://www.visualsvn.com/downloads/ 2. 下载SVN 命令行工具后&#xff0c;解压后就可以了&#xff0c;不需要安装的 3. 将bin 文件添加到系统环境变量中&#xff0c;不知道怎么打开系统环境变量的自己问度娘 4. 添加到系统环境变量中&#xff0c;…

21.CSS的动态圆形进度条

效果 源码 <!doctype html> <html><head><meta charset="utf-8"><title>Animated Circular Progress | CSS Only</title><link rel="stylesheet" href="style.css"></head><body><di…

K8S自动化运维容器Docker集群

K8S&#xff1a;K8S自动化运维容器化(Docker)集群 一.k8s概述 1.k8s是什么 &#xff08;1&#xff09;K8S全程为Kubernetes&#xff0c;由于K到S直接有8个字母简称为K8S。 &#xff08;2&#xff09;版本&#xff1a;目前一般是1.18~1.2.0&#xff0c;后续可能会到1.24-1.2…

「解析」YOLOv5 classify分类模板

学习深度学习有些时间了&#xff0c;相信很多小伙伴都已经接触 图像分类、目标检测甚至图像分割(语义分割)等算法了&#xff0c;相信大部分小伙伴都是从分类入门&#xff0c;接触各式各样的 Backbone算法开启自己的炼丹之路。 但是炼丹并非全是 Backbone&#xff0c;更多的是各…

为C# Console应用化个妆

说到Windows的cmd&#xff0c;刻板印象就是黑底白字的命令行界面。跟Linux花花绿绿的界面比&#xff0c;似乎单调了许多。但其实C#开发的Console应用也可以摆脱单调非黑即白的UI。 最近遇到个需求&#xff0c;要在一堆纯文本文件里找指定的关键字&#xff08;后续还要人肉判断…

LMD-恶意软件检测工具

LMD是Linux恶意软件扫描器&#xff0c;以GNU GLPv2许可发布。 官方地址&#xff1a;https://www.rfxn.com 下载软件包命令&#xff1a; wget https://www.rfxn.com/downloads/maldetect-current.tar.gz tar命令解包后进入其目录。 安装命令如下&#xff1a; ./install.sh …

〔021〕Stable Diffusion 之 提示词反推、自动补全、中文输入 篇

✨ 目录 &#x1f388; 反推提示词 / Tagger&#x1f388; 反推提示词 Tagger 使用&#x1f388; 英文提示词自动补全 / Booru tag&#x1f388; 英文提示词自动补全 Booru tag 使用&#x1f388; 中文提示词自动补全 / tagcomplete&#x1f388; 中文提示词自动补全 tagcomple…

说说IO多路复用

分析&回答 IO多路复用 I/O multiplexing 这里面的 multiplexing 指的其实是在单个线程通过记录跟踪每一个Sock(I/O流)的状态(对应空管塔里面的Fight progress strip槽)来同时管理多个I/O流。直白点说&#xff1a;多路指的是多个socket连接&#xff0c;复用指的是复用一个…

如何创建美观的邮件模板并通过qq邮箱的SMTP服务向用户发送

最近在写注册功能的自动发送邮箱告知验证码的功能&#xff0c;无奈根本没有学过前端&#xff0c;只有写Qt的qss基础&#xff0c;只好借助网页设计自己想要的邮箱格式&#xff0c;最终效果如下: 也推销一下自己的项目ShaderLab&#xff0c;可运行ShaderToy上的大部分着色器代码&…

npm install 包的时候,提示安装成功,但是项目中没有出现,node_modules也没有安装的包,package.json中也没有任何依赖包记录

——这种情况一般是包安装错了目录&#xff01; 解决步骤&#xff1a; 1. 查看npm的配置 npm config list2.查看全局下&#xff0c;是否有自己安装的包 npm root -g//获取到全局安装目录找到返回的地址中是否有自己安装的包 3.修改npm配置信息&#xff0c;查看 图例1&…

postgis数据库从一张表中过滤出一部分数据到新表中

你可以使用以下步骤在PostGIS数据库中过滤objectid<100的数据&#xff0c;并将其创建为新表&#xff1a;打开PostGIS数据库的终端或客户端工具&#xff08;如Psql&#xff09;。 选择你要过滤数据的表。假设表名为"original_table"&#xff0c;该表包含一个名为&q…

【C++】函数参数扩展 ② ( 占位参数 | 占位参数规则 - 必须为占位参数传入实参 | 默认参数与占位参数结合使用 )

文章目录 一、占位参数1、占位参数简介2、占位参数规则 - 必须为占位参数传入实参 二、默认参数与占位参数结合使用1、结合用法2、代码示例 - 占位参数与默认参数结合用法 博客总结 : 默认参数 : 在 声明 函数时 , 为 函数参数 定义一个默认值 ;默认参数规则 : " 默认参数…

时序预测 | MATLAB实现TCN-GRU时间卷积门控循环单元时间序列预测

时序预测 | MATLAB实现TCN-GRU时间卷积门控循环单元时间序列预测 目录 时序预测 | MATLAB实现TCN-GRU时间卷积门控循环单元时间序列预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 1.MATLAB实现TCN-GRU时间卷积门控循环单元时间序列预测&#xff1b; 2.运行环…

【工程实践】使用git clone 批量下载huggingface模型文件

前言 经常需要下载模型到服务器&#xff0c;使用git clone方法可以快速实现模型下载。 1.选定要下载的模型 以下载moka-ai/m3e-base为例&#xff0c;切换到Files and versions。 2.更改下载网页的url 如上图所示&#xff0c;当前要下载模型网页的url为&#xff1a; https://hu…

SpringMVC使用

文章目录 一.MVC基础概念1.MVC定义2.SpringMVC和MVC的关系 二.SpringMVC的使用1.RequestMapping2.获取参数1.获取单个参数2.传递对象3.后端参数重命名&#xff08;后端参数映射&#xff09;4.获取URL中参数PathVariable5.上传文件RequestPart6.获取Cookie/Session/header 3.返回…

数据可视化工具中的显眼包:奥威BI自带方案上阵

根据经验来看&#xff0c;BI数据可视化分析项目是由BI数据可视化工具和数据分析方案两大部分共同组成&#xff0c;且大多数时候方案都需从零开始&#xff0c;反复调整&#xff0c;会耗费大量时间精力成本。而奥威BI数据可视化工具别具匠心&#xff0c;将17年经验凝聚成标准化、…

算法训练 第一周

一、合并两个有序数组 本题给出了两个整数数组nums1和nums2&#xff0c;这两个数组均是非递减排列&#xff0c;要求我们将这两个数组合并成一个非递减排列的数组。题目中还要求我们把合并完的数组存储在nums1中&#xff0c;并且为了存储两个数组中全部的数据&#xff0c;nums1中…

VLAN间路由:单臂路由与三层交换

文章目录 一、定义二、实现方式单臂路由三层交换 三、单臂路由与三层路由优缺点对比四、常用命令 首先可以看下思维导图&#xff0c;以便更好的理解接下来的内容。 一、定义 VLAN间路由是一种网络配置方法&#xff0c;旨在实现不同虚拟局域网&#xff08;VLAN&#xff09;之…