使用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/zh-tw/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

發表回復

登錄後才能評論