基於Python實現excel表格讀寫

来源:https://www.cnblogs.com/pythonedu/archive/2018/05/16/9048223.html
-Advertisement-
Play Games

摘要: 考慮到VBA寫不好但是有對批量化處理數據的需求,所以推薦Python自帶的xlrd和xlwt庫對Excel表格數據進行讀寫操作。簡明的代碼風格很適合上手。 首先安裝對應的xlrd和xlwt 打開cmd命令視窗輸入pip install xlrd和pip install xlwt就可以安裝。之 ...


摘要: 考慮到VBA寫不好但是有對批量化處理數據的需求,所以推薦Python自帶的xlrd和xlwt庫對Excel表格數據進行讀寫操作。簡明的代碼風格很適合上手。

 

首先安裝對應的xlrd和xlwt

打開cmd命令視窗輸入pip install xlrd和pip install xlwt就可以安裝。之後輸入pip list檢查是否成功配置:

 

 

xlrd操作#

接下來就是常用的語法操作:

 

excel_data = xlrd.open_workbook(文件路徑')#得到對應的工作表

sheet = excel_data.sheets()[工作表序號]#得到對應工作表中的某一個表格

sheet.row_values(2)#對應的某一行的數據

sheet.cell(6,1).value#對應某一列的數據

 

 

 

以該表格為例先試一下對應的語句:

先指定對應的表格和其中的某一個表,否則會提示出錯編譯不通過。將以上代碼運行得到:   

源碼如下:

import xlrd

import xlwt

excel_data = xlrd.open_workbook(文件路徑')

excel_data = xlrd.open_workbook(r'C:\Users\hys mac\Desktop\實用的excel表格模板.xls')

sheet = excel_data.sheets()[工作表序號]

sheet = excel_data.sheets()[0]

print(sheet.row_values(2)) #列印某一行數據

print(sheet.col_values(1))#列印某一列

print( )

print ( sheet.cell(6,1).value)#列印某個具體值

 

運行結果如下:

 

 

對比表格得到一些值得註意的地方,指定的行數列數是從0開始,打開指定的表格時要註意絕對路徑時要連同文件名和文件尾碼也要帶上才能成功讀取數據。

 

 

接下來實驗讀取指定的某個單元格的數據:

 

sheet.cell(行,列).value

 

 

運行得到:

 

對比表格得到數據:

 

是其中的(7,B),和之前提到的從零開始計數是一致的。

 

    除了以上列舉的一些操作外還有其他的常見語句可以在相關文檔和官網中查看,文末有相關鏈接,接下來實驗另一個xlwt庫以實現對excel表格的寫入操作。

xlwt操作#

    對於excel表格一般關心的問題在於以下幾個方面:

  • 創建工作薄和表
  • 寫入單元格
  • 常見格式設置(貨幣文本等)
  • 創建公式
  • 保存

接下來依次嘗試以上提到的各個功能:

  1. 工作薄和表對應的對象為:workbook,sheet

      

      2.單元格賦值:

        

    這裡嘗試了一下採用負數

       

    編譯沒有問題留作後面保存後檢查結果是否正確。

        3.格式設置:

        

       可見對應傳入參數除行列和值外還包括style這一預設省略的參數。這裡試驗設置的格式為加粗。其他格式可以參照查找文末文檔實現。這裡有一些常見得其他格式:

style = easyxf(num_format_str='$#,##0.00')

# or set it directly on the style object

style = easyxf('font: bold 1')

style.num_format_str = '$#,##0.00'

sheet.write(0, 0, '100.00', style)

        4.創建公式:

        使用xlwt.Formula可以實現Excel公式。

        sheet.write(0, 0, xlwt.Formula('HYPERLINK("http://yujitomita.com"; "click me")'))

        5.保存操作:

        workbook.save("Python.xls")

        wbk.save('路徑名')    

        這裡值得提醒的是工作表的命名要小於31個字元且不能包括特殊字元(:。,等)。

     運行結果:

        按照之前的坑(-1,0)這裡試運行結果:

# encoding : utf-8 
import xlrd
import xlwt

workbook = xlwt.Workbook() 
sheet = workbook.add_sheet("Sheet 1") 

#創建工作簿(workbook)和工作表(sheet)

sheet.write(-1, 0, 'Python')#行列對應

style = xlwt.easyxf('font: bold 1')
sheet.write(1, 1, 'style ', style)

workbook.save('C:\Users\hys mac\Desktop\mr.c\python.xls') 

       報錯結果如下:

SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in position 2-3: truncated \UXXXXXXXX escape

        遇到了文件編碼的問題,修改後一句:

workbook.save(r'C:\Users\hys mac\Desktop\mr.c\python.xls')          

        就回到了一開始留下的坑,單元格賦值規則應該與使用習慣一致不能為負數。最後修改得到:

import xlrd
import xlwt

workbook = xlwt.Workbook() 
sheet = workbook.add_sheet("Sheet 1") 

#創建工作簿(workbook)和工作表(sheet)

sheet.write(1, 0, 'Python')#行列對應

style = xlwt.easyxf('font: bold 1')
sheet.write(1, 1, 'style ', style)

workbook.save(r'C:\Users\hys mac\Desktop\mr.c\python1.xls')  #文件路徑要存在且不能同名

        結語和資料:

        到這裡這兩個excel處理的模塊操作基本結束了,還有其他實現相關功能的模塊例如 openpyxl和win32com等有機會再寫一篇作為橫向對比的博文。https://www.zhihu.com/people/dou-wo-45知乎傳送門歡迎留言交流。創作不易,保留權利。python學習交流群:125240963

轉載至:https://my.oschina.net/aichirou/blog/683444
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 類:(是一個獨立存放變數(屬性/方法)的空間) class 類名:(類名,每個單詞的首字母大寫) pass 實例 = 類 (類是一類事物的抽象,不是真的存在的。實例是某類事物的具體個體) 類的私有屬性: _x:(一個下劃線的私有屬性類和子類可以訪問) __x:(兩個前置下劃線的私有屬性,無法在外部直 ...
  • 索引: 開源Spring解決方案--lm.solution 參看代碼 GitHub: pom.xml WebConfig.java index.jsp upload.jsp FileUploadController.java Files_Utils_DG.java 一、要點講解 1.引入文件上傳下載 ...
  • 在項目開發過程中或者是性能優化中,經常會有要查看執行sql的情況,然而Laravel日誌預設不記錄執行sql。好在留有相關介面,我們可以很方便的就是想SQl日誌功能。 2.創建SqlListener監聽器 1 > php artisan event:generate 在handle方法中編寫記錄sq ...
  • 爬蟲的原理 現在,讓我們踩下油門,開始飆車!!! 既然我們要基於面向對象的思想寫這個爬蟲,那麼我們就需要把這個爬蟲寫成一個類。 註意力不要放在妹子上!!! 我們定位到妹子的url,我們可以很容易的寫出妹子url的xpath。 調出開發者工具(註意力不要放在妹子上!!!) 兩種解決辦法: 下麵我們使用 ...
  • 筆者也是一個linux新手,最近在學習linux相關的東西,本人是一個node愛好者,想在linux上寫一個linux服務,我的環境是centeros7,用putty鏈接遠端的伺服器,要想讓服務在服務端運行 常用的方法是: 運用nohup命令將服務重定向到output.log文件中,這樣就可以實現l ...
  • __new__ : 這個方法的作用主要是創建一個實例,在創建實例時首先會調用 __new__方法 ,然後調用__init__對實例進行初始化, 如果想修改 __new__ 這個方法,那麼最後要 return 調用一下父類的 __new__ 方法,因為裡面有創建實例的過程,除非你在自定義的 __new ...
  • final final在Java中是一個保留的關鍵字,可以聲明成員變數、方法、類以及本地變數。一旦你將引用聲明作final,你將不能改變這個引用了,編譯器會檢查代碼,如果你試圖將變數再次初始化的話,編譯器會報編譯錯誤。 修飾變數(例如Math類的PI=3.1415926就是變數不可修改) 用fina ...
  • 1:/usr/lib/ruby/gems/1.8/gems/redis-3.0.7/lib/redis/client.rb:97:in `call': ERR Slot 16011 is already busy (Redis::CommandError)這是由於上一次配置集群失敗時留下的配置信息導 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...