Python 操作 MS Excel 文件

来源:http://www.cnblogs.com/wuzhiblog/archive/2016/07/10/pythonexcel.html
-Advertisement-
Play Games

利用 Python 對 Excel 文件進行操作需要使用第三方庫: openpyxl,可執行 pip install openpyxl 進行安裝 1. 導入 openpyxl 模塊 導入 openpyxl 模塊後,利用它的 load_workbook() 方法可以打開一個 Excel 文件,該方法使 ...


利用 Python 對 Excel 文件進行操作需要使用第三方庫: openpyxl,可執行 pip install openpyxl 進行安裝

1. 導入 openpyxl 模塊

導入 openpyxl 模塊後,利用它的 load_workbook() 方法可以打開一個 Excel 文件,該方法使用一個文件名稱作為參數,示例如下:

>>> import openpyxl

>>> wb = openpyxl.load_workbook('example.xlsx')

>>> type(wb)

<class 'openpyxl.workbook.workbook.Workbook'>

2. openpyxl 常用方法

可以使用 openpyxl 對象的 get_sheet_names() 方法得到打開的工作薄中存在的所有工作表名稱、用 get_sheet_by_name() 方法獲取工作表對象、用 active 屬性可獲取當前活躍工作表的名稱:

>>> wb.get_sheet_names()

['Sheet1', 'Sheet2', 'Sheet3']

>>> sheet = wb.get_sheet_by_name('Sheet3')

>>> sheet

<Worksheet "Sheet3">

>>> type(sheet)

<class 'openpyxl.worksheet.worksheet.Worksheet'>

>>> sheet.title

'Sheet3'

>>> anotherSheet = wb.active

>>> anotherSheet

<Worksheet "Sheet1">

3. 獲取單元格屬性

可以直接使用單元格名稱獲取指定單元格,同時單元格具有值、行、列、坐標屬性,舉例如下:

>>> sheet = wb.get_sheet_by_name('Sheet1')

>>> sheet['A1']

<Cell Sheet1.A1>

>>> sheet['A1'].value

datetime.datetime(2015, 4, 5, 13, 34, 2)

>>> c = sheet['B1']

>>> c.value

'Apples'

>>> 'Row ' + str(c.row) + ', Column ' + c.column + ' is ' + c.value

'Row 1, Column B is Apples'

>>> 'Cell ' + c.coordinate + ' is ' + c.value

'Cell B1 is Apples'

>>> sheet['C1'].value

73

4. 使用 cell()

同時也可以使用工作表對象的 cell() 方法來直接指定單元格,使用該方法時要註意,工作表中的行、列都是從1而不是0開始的:

>>> sheet.cell(row=1, column=2)

<Cell Sheet1.B1>

>>> sheet.cell(row=1, column=2).value

'Apples'

>>> for i in range(1, 8, 2):

             print(i, sheet.cell(row=i, column=2).value)

1 Apples

3 Pears

5 Apples

7 Strawberries

5. 獲取當前工作表中有效數據區域的行數和列數

>>> sheet.max_row

7

>>> sheet.max_column

3

6. 行、列之間的轉換

需要使用 get_column_letter、column_index_from_string 這兩個方法

>>> from openpyxl.cell import get_column_letter, column_index_from_string

>>> get_column_letter(1)

'A'

>>> get_column_letter(2)

'B'

>>> get_column_letter(27)

'AA'

>>> get_column_letter(900)

'AHP'

>>> get_column_letter(sheet.max_column)

'C'

>>> column_index_from_string('A')

1

>>> column_index_from_string('AA')

27

7. 獲取區域數據

>>> tuple(sheet['A1':'C3'])

((<Cell Sheet1.A1>, <Cell Sheet1.B1>, <Cell Sheet1.C1>), (<Cell Sheet1.A2>, <Cell Sheet1.B2>, <Cell Sheet1.C2>), (<Cell Sheet1.A3>, <Cell Sheet1.B3>, <Cell Sheet1.C3>))

8. 獲取指定一行或一列數據

>>> sheet.columns[1]

(<Cell Sheet1.B1>, <Cell Sheet1.B2>, <Cell Sheet1.B3>, <Cell Sheet1.B4>, <Cell Sheet1.B5>, <Cell Sheet1.B6>, <Cell Sheet1.B7>)

 9. 總結

利用 openpyxl 對 excel 文件進行操作,主要步驟有以下幾點:

  • 導入 openpyxl 模塊
  • 調用 openpyxl.load_workbook() 函數
  • 獲得 Workbook 對象
  • 讀取活躍工作表變數或者調用 get_sheet_by_name() 方法
  • 獲得 Worksheet 對象
  • 使用索引或使用行、列關鍵詞調用工作表的 cell() 方法
  • 獲得 Cell 對象
  • 讀取 Cell 對象的屬性值

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • .net core最近園子討論頻率很高的話題,從不久前發佈正式版本後,也是開始從netcore官網一步一步走向學習之路;.net跨平臺的設計讓人很是興奮起來,因為做了多年的互聯網研發者,見識了很多一流大公司對之的態度,在很多應用方面幾乎看不到影子,深深感覺發展前景不是很樂觀,但現在不同以往跨平臺,加 ...
  • IAuthenticationFilter是MVC5中的新特性,它有2個關鍵方法: OnAuthentication OnAuthenticationChallenge 當IAuthenticationFilter和IAuthorizationFilter結合使用時,流程看似比較複雜: 在OnAut ...
  • 官方的文檔https://docs.asp.net/en/latest/tutorials/first-mvc-app/start-mvc.html 先來看一下實現的效果 開始之前,確定本機已經有.NET Core環境。https://www.microsoft.com/net/core#windo ...
  • C 可以直接引用C++的DLL和轉換JAVA寫好的程式。最近由於工作原因接觸這方面比較多,根據實際需求,我們通過一個具體例子把一個JAVA方法轉換成可以由C 直接調用的DLL C 調用c++ C 調用C++的例子網上很多,以一個C++的具體方法為例。 C++代碼 C 代碼 這樣我們把這個DLL放在程 ...
  • 一、struts.xml中<package>的namespace屬性的用法 在實際的開發中常會遇到name相同的<action>,如下代碼: 以上的配置中在同一個namespace下有兩個相同name為add的<action>,這樣就不能區別了,為瞭解決這個問題,我們可以把兩個<action>放在不 ...
  • 這次的解題報告是有關tarjan演算法的一道思維量比較大的題目(真的是原創文章,希望管理員不要再把文章移出首頁)。 這道題蒟蒻以前做過,但是今天由於要複習tarjan演算法,於是就看到codevs分類強聯通分量裡面只有這一道題。 題目是這樣的: 這是一個有向圖上的問題,這道題很容易看出來一個愛心天使就是 ...
  • 本文記錄了在windows系統中使用C-FREE 5新建一個Hello HoverTree程式的步驟。安裝好C-Free 5之後,打開。新建一個工程:附C-Free 5下載:http://hovertree.com/h/bjaf/xrjx4nht.htm選擇工程類型,保存位置,並輸入工程名稱,這裡選 ...
  • 一、Java讀取文件 案例1:讀取D盤的1.txt文件 編碼: 結果: 二、寫入文件 案例:講D盤中的1.txt文件內容寫入D盤一個2.txt文件。 編碼: ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...