我用Python操作Excel的两种主要工具

简介: 我用Python操作Excel的两种主要工具

Python操作Excel分为两个主要形式,读写和交互式操作,可以用不同的第三方工具。

首先对于单纯地读写Excel,这种场景使用Pandas就足够了。

使用Pandas中的read_excel、to_excel函数,在Excel和DataFrame格式间进行转换。

import pandas as pd
# 读取excel文件,Excel->DataFrame
df = pd.read_excel('example.xlsx')
# 导出excel文件,DataFrame->Excel
df.to_excel('example.xlsx')

其他的诸如xlrd、xlwt功能单一,也没有Pandas好用。

Pandas针对excel设置了丰富的参数选项,将近30个,基本可以满足你大部分读写需求。

pandas.read_excel(io,sheet_name=0,*,header=0,names=None,index_col=None,usecols=None,dtype=None)

  • io:string类型文件的路径或url
  • sheet_name=0:指定的excel中的具体某个或某些表的表名或表索引
  • header=0:以哪些行作为表头,也叫做列名
  • names=None:自己定义一个表头(列名)
  • index_col=None:将哪些列设为索引.
  • usecols=None:指定读取excel中哪些列的数据,默认为None,表示读取全部
  • squeeze=False:默认为False,如果解析的数据只包含一列,则返回一个Series
  • dtype=None:接收dict,设置数据类型,具体到每列


其次是针对Excel文件本身的交互操作,比如修改格式、制作图表、透视表、宏等,这种操作需要用到专门的Excel处理库,像xlwings、openpyxl等。

这里重点讲讲xlwings,xlwings是比较专业全面的Excel操作库,可以使用Python自动化操作Excel中的任何功能,比如可视化、格式处理、数据透视等。

1950a700f817754eed8b5535ba4a0aa3.png

xlwings很好的将Python中的Pandas、Numpy、matplotlib与Excel进行交互,例如数据格式转换等。

# 将matplotlib图像贴入Excel中
import matplotlib.pyplot as plt
import xlwings as xw
fig = plt.figure()
plt.plot([1, 2, 3])
sheet = xw.Book().sheets[0]
sheet.pictures.add(fig, name='MyPlot', update=True)

4f7b32217748bd462527557682e26dcc.png

xlwing还有excel插件,可以支持在excel中编写python代码,执行自动化任务。

a01e5f229a79cb4bd404e5b141d05d41.png

相关文章
|
26天前
|
人工智能 Python
读取excel工具:openpyxl | AI应用开发
`openpyxl` 是一个 Python 库,专门用于读写 Excel 2010 xlsx/xlsm/xltx/xltm 文件。它是处理 Excel 文件的强大工具,可以让你在不需要安装 Excel 软件的情况下,对 Excel 文件进行创建、修改、读取和写入操作【10月更文挑战第3天】
56 0
|
25天前
|
数据处理 Python
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
这篇文章介绍了如何使用Python读取Excel文件中的数据,处理后将其保存为txt、xlsx和csv格式的文件。
42 3
Python实用记录(十):获取excel数据并通过列表的形式保存为txt文档、xlsx文档、csv文档
|
10天前
|
数据处理
在Excel中,通配符是一种强大的工具
【10月更文挑战第23天】在Excel中,通配符是一种强大的工具
12 4
|
12天前
|
数据采集 数据可视化 数据挖掘
R语言与Python:比较两种数据分析工具
R语言和Python是目前最流行的两种数据分析工具。本文将对这两种工具进行比较,包括它们的历史、特点、应用场景、社区支持、学习资源、性能等方面,以帮助读者更好地了解和选择适合自己的数据分析工具。
19 2
|
12天前
|
C语言 开发者 Python
探索Python中的列表推导式:简洁而强大的工具
【10月更文挑战第21天】在Python的世界里,代码的优雅与效率同样重要。列表推导式(List Comprehensions)作为一种强大而简洁的工具,允许开发者通过一行代码完成对列表的复杂操作。本文将深入探讨列表推导式的使用方法、性能考量以及它如何提升代码的可读性和效率。
|
14天前
|
Python
python读写操作excel日志
主要是读写操作,创建表格
47 2
|
22天前
|
自然语言处理 算法 数据挖掘
探讨如何利用Python中的NLP工具,从被动收集到主动分析文本数据的过程
【10月更文挑战第11天】本文介绍了自然语言处理(NLP)在文本分析中的应用,从被动收集到主动分析的过程。通过Python代码示例,详细展示了文本预处理、特征提取、情感分析和主题建模等关键技术,帮助读者理解如何有效利用NLP工具进行文本数据分析。
40 2
|
29天前
|
测试技术 Python
Python MagicMock: Mock 变量的强大工具
Python MagicMock: Mock 变量的强大工具
|
1月前
|
存储 Python
python数据类型、debug工具(一)
python数据类型、debug工具(一)
|
9天前
|
C语言 Python
探索Python中的列表推导式:简洁而强大的工具
【10月更文挑战第24天】在Python编程的世界中,追求代码的简洁性和可读性是永恒的主题。列表推导式(List Comprehensions)作为Python语言的一个特色功能,提供了一种优雅且高效的方法来创建和处理列表。本文将深入探讨列表推导式的使用场景、语法结构以及如何通过它简化日常编程任务。