使用openpyxl操作Excel

介绍

Excel是一款非常常用的办公软件。在日常的工作生活中,我们会经常使用它来进行数据的存储和处理。而Python作为非常强大的编程语言,也提供了很多库来操作Excel文件。其中比较出名的是openpyxl库。它可以让我们非常方便地读取和编辑Excel文件,而且使用起来非常简单。接下来,我们就来详细介绍一下如何使用openpyxl操作Excel。

安装openpyxl库

在开始使用openpyxl之前,我们需要先安装该库。可以通过以下方式来安装openpyxl:

pip install openpyxl

打开Excel文件

使用openpyxl库,打开Excel文件非常简单,只需要调用openpyxl.load_workbook()方法即可。例如,我们有一个名为example.xlsx的Excel文件,可以使用以下代码打开它:

from openpyxl import load_workbook

workbook = load_workbook('example.xlsx')

注意,openpyxl只支持xlsx格式的Excel文件,不支持xls格式的文件。

读取Excel文件中的数据

在打开Excel文件之后,我们就可以读取其中的数据了。openpyxl提供了非常简单的接口来读取Excel文件中的数据。例如,我们要读取Excel文件中的第一个工作表的所有行和列,可以使用以下代码:

sheet = workbook.active # 获取第一个工作表

for row in sheet.iter_rows():
    for cell in row:
        print(cell.value)

以上代码会遍历第一个工作表的所有单元格,输出它们的值。如果要读取指定的工作表,可以使用以下方式:

sheet = workbook['Sheet1'] # 读取名为Sheet1的工作表

接下来,我们将从以下几个方面来详细介绍openpyxl读取Excel文件的方法:

1、读取单元格的值

有时候我们只需要读取单元格中的值,可以使用以下方式:

sheet = workbook.active
print(sheet['A1'].value) # 读取A1单元格的值

以上代码会输出A1单元格的值。

2、读取行和列的值

如果要读取整行或整列的值,可以使用以下代码:

sheet = workbook.active
row_values = []
for row in sheet.iter_rows(min_row=1, max_row=1):
    for cell in row:
        row_values.append(cell.value)
print(row_values) # 输出第1行的所有值

col_values = []
for col in sheet.iter_cols(min_col=1, max_col=1):
    for cell in col:
        col_values.append(cell.value)
print(col_values) # 输出第1列的所有值

以上代码会输出第1行和第1列的所有值。

3、读取指定区域的值

如果要读取指定的区域的值,可以使用以下代码:

sheet = workbook.active
for row in sheet.iter_rows(min_row=1, max_row=3, min_col=1, max_col=3):
    for cell in row:
        print(cell.value)

以上代码会输出第1行到第3行、第1列到第3列的所有单元格的值。

4、读取指定单元格所在的行和列

如果想读取某个单元格所在的行和列,可以使用以下代码:

from openpyxl.utils import column_index_from_string

sheet = workbook.active
cell = sheet['B3']
print(cell.row) # 输出B3单元格的行号
print(column_index_from_string(cell.column)) # 输出B3单元格的列号

以上代码会输出B3单元格的行号和列号(从1开始计数)。

写入Excel文件

与读取Excel文件相比,写入Excel文件稍微麻烦一些。不过,openpyxl提供了非常方便的接口来实现这一功能。以下是一些常用的写入Excel文件的方法。

1、创建和删除工作表

要创建一个新的工作表,可以使用以下代码:

from openpyxl import Workbook

workbook = Workbook() # 创建一个新的Excel文件
sheet = workbook.active
sheet.title = 'Sheet1' # 重命名第一个工作表
workbook.create_sheet('Sheet2') # 创建名为Sheet2的工作表
workbook.save('example.xlsx') # 保存Excel文件

以上代码会创建一个新的Excel文件,并在其中创建两个工作表(Sheet1和Sheet2)。

如果要删除工作表,可以使用以下代码:

from openpyxl import load_workbook

workbook = load_workbook('example.xlsx')
del workbook['Sheet1'] # 删除名为Sheet1的工作表
workbook.save('example.xlsx') # 保存Excel文件

以上代码会删除名为Sheet1的工作表。

2、写入单元格的值

要写入单元格的值,可以使用以下代码:

sheet = workbook.active
sheet['A1'] = 'hello, world!'
workbook.save('example.xlsx') # 保存Excel文件

以上代码会在A1单元格中写入hello, world!。

3、写入行和列的值

如果要写入整行或整列的值,可以使用以下代码:

sheet = workbook.active
row_values = ['apple', 'banana', 'orange']
sheet.append(row_values) # 在末尾添加一行数据
col_values = ['red', 'green', 'blue']
for i in range(len(col_values)):
    sheet.cell(row=i+1, column=1, value=col_values[i]) # 写入第1列的所有值
workbook.save('example.xlsx') # 保存Excel文件

以上代码会在末尾添加一行数据,以及写入第1列的所有值。

4、写入复杂的数据结构

如果要写入比较复杂的数据结构,可以使用以下代码:

from openpyxl.utils import get_column_letter

sheet = workbook.active
data = [
    ['Name', 'Age', 'Gender'],
    ['Tom', 20, 'M'],
    ['Mary', 25, 'F'],
    ['Jack', 30, 'M'],
]
for row_index, row_data in enumerate(data):
    for col_index, col_data in enumerate(row_data):
        col_letter = get_column_letter(col_index+1)
        sheet['{}{}'.format(col_letter, row_index+1)] = col_data
workbook.save('example.xlsx') # 保存Excel文件

以上代码会将一个二维列表写入Excel文件,其中第一行是列名,其他行是数据。

小结

本文介绍了如何使用openpyxl库来读取和写入Excel文件。我们有详细地介绍了openpyxl的一些常用接口,例如打开Excel文件、读取单元格、写入单元格等等。希望这篇文章可以帮助到大家!

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/245327.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-12-12 13:08
下一篇 2024-12-12 13:08

相关推荐

  • Python栈操作用法介绍

    如果你是一位Python开发工程师,那么你必须掌握Python中的栈操作。在Python中,栈是一个容器,提供后进先出(LIFO)的原则。这篇文章将通过多个方面详细地阐述Pytho…

    编程 2025-04-29
  • Python操作数组

    本文将从多个方面详细介绍如何使用Python操作5个数组成的列表。 一、数组的定义 数组是一种用于存储相同类型数据的数据结构。Python中的数组是通过列表来实现的,列表中可以存放…

    编程 2025-04-29
  • Python操作MySQL

    本文将从以下几个方面对Python操作MySQL进行详细阐述: 一、连接MySQL数据库 在使用Python操作MySQL之前,我们需要先连接MySQL数据库。在Python中,我…

    编程 2025-04-29
  • Python磁盘操作全方位解析

    本篇文章将从多个方面对Python磁盘操作进行详细阐述,包括文件读写、文件夹创建、删除、文件搜索与遍历、文件重命名、移动、复制、文件权限修改等常用操作。 一、文件读写操作 文件读写…

    编程 2025-04-29
  • Python代码实现回文数最少操作次数

    本文将介绍如何使用Python解决一道经典的回文数问题:给定一个数n,按照一定规则对它进行若干次操作,使得n成为回文数,求最少的操作次数。 一、问题分析 首先,我们需要了解回文数的…

    编程 2025-04-29
  • 为什么不能用Microsoft Excel进行Python编程?

    Microsoft Excel是一个广泛使用的数据分析工具,但是它不能直接用于Python编程。这是因为Microsoft Excel并不是一个编程工具,它的主要功能是进行数据处理…

    编程 2025-04-29
  • Python元祖操作用法介绍

    本文将从多个方面对Python元祖的操作进行详细阐述。包括:元祖定义及初始化、元祖遍历、元祖切片、元祖合并及比较、元祖解包等内容。 一、元祖定义及初始化 元祖在Python中属于序…

    编程 2025-04-29
  • Python列表的读写操作

    本文将针对Python列表的读取与写入操作进行详细的阐述,包括列表的基本操作、列表的增删改查、列表切片、列表排序、列表反转、列表拼接、列表复制等操作。 一、列表的基本操作 列表是P…

    编程 2025-04-29
  • 如何用Python对数据进行离散化操作

    数据离散化是指将连续的数据转化为离散的数据,一般是用于数据挖掘和数据分析中,可以帮助我们更好的理解数据,从而更好地进行决策和分析。Python作为一种高效的编程语言,在数据处理和分…

    编程 2025-04-29
  • Python序列的常用操作

    Python序列是程序中的重要工具,在数据分析、机器学习、图像处理等很多领域都有广泛的应用。Python序列分为三种:列表(list)、元组(tuple)和字符串(string)。…

    编程 2025-04-28

发表回复

登录后才能评论