我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

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

在这里插入图片描述

xlwings模块详解

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)

输出:

工作簿1Sheets([<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():删除单元格

来源地址:https://blog.csdn.net/wangyuxiang946/article/details/132249339

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python安装Graphviz超详细图文教程

这篇文章主要介绍了Python安装Graphviz详细教程,在Python安装Graphviz画图器,首先要明确他是一个独立的软件,如果大家用pip的方法装了graphviz可以先卸载,本文通过图文并茂的形式详细讲解,需要的朋友参考下吧
2023-02-09

Python操作Redis数据库的超详细教程

目录介绍常用数据结构安装连接String 字符串(键值对)List 列表Hash 哈希Set 集合Zset 有序集合Bitmap 位图全局函数总结介绍Redis是一个开源的基于内存也可持久化的Key-Value数据库,采用ANSI C语言
2022-06-23

python操作MySQL的详细教程

目录前言一、Pymysql的特点二、安装三、基本用法(一)连接MySQL数据库(二)数据查询(三)插入数据(四)更新和删除数据(五)事务管理四、游标类型五、安全性六、常见错误处理七、性能优化八、总结前言PyMySQL 是一个纯 pytho
python操作MySQL的详细教程
2024-10-09

Windows下Python使用Pandas模块操作Excel文件的教程

安装Python环境 ANACONDA是一个Python的发行版本,包含了400多个Python最常用的库,其中就包括了数据分析中需要经常使用到的Numpy和Pandas等。更重要的是,不论在哪个平台上,都可以一键安装,自动配置好环境,不需
2022-06-04

图文详解Python中模块或py文件导入(超详细!)

导入文件目的就是为了执行文件,下面这篇文章主要给大家介绍了关于Python中模块或py文件导入的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
2023-05-16

python使用openai生成图像的超详细教程

OpenAI成功地训练了一个能够从文字标题生成图像的网络,它非常类似于GPT-3和图像GPT,并产生惊人的结果,下面这篇文章主要给大家介绍了关于python使用openai生成图像的超详细教程,需要的朋友可以参考下
2023-03-19

Python安装Talib库的详细图文教程

talib库的安装之路坑特别多,这是最常见的,下面这篇文章主要给大家介绍了关于Python安装Talib库的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
2022-12-23

Java中File文件操作类的超详细使用教程

File类在包java.io.File下、代表操作系统的文件对象(文件、文件夹),File类提供了诸如:定位文件,获取文件本身的信息、删除文件、创建文件(文件夹)等功能,下面这篇文章主要给大家介绍了关于Java中File文件操作类的超详细使用教程,需要的朋友可以参考下
2023-01-18

pycharm配置python环境的详细图文教程

PyCharm是一款功能强大的Python编辑器,具有跨平台性,下面这篇文章主要给大家介绍了关于pycharm配置python环境的详细图文教程,文中通过图文介绍的非常详细,需要的朋友可以参考下
2023-01-07

Win8系统定位功能详细操作图文教程

微软在设计的时候为Win8系统加入了一个特别的功能,即系统定位,这个服务不提供超想、高度、速度、地址等js,但却给用户的生活、工作带来了很多方便的地方,下面我们来看下这个定位功能的详细操作。设置jsWin8系统定位功能的方法:1、首先使用组
2023-06-06

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录