校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 淺談Python xlwings 讀取Excel文件的正確姿勢

淺談Python xlwings 讀取Excel文件的正確姿勢

熱門標簽:正安縣地圖標注app 螳螂科技外呼系統怎么用 電銷機器人系統廠家鄭州 地圖地圖標注有嘆號 遼寧智能外呼系統需要多少錢 阿里電話機器人對話 qt百度地圖標注 400電話申請資格 舉辦過冬奧會的城市地圖標注

使用Python加載最新的Excel讀取類庫xlwings可以說是Excel數據處理的利器,但使用起來還是有一些注意事項,否則高大上的Python會跑的比老舊的VBA還要慢。

這里我們對比一下,用幾種不同的方法,從一個Excel表格中讀取一萬行數據,然后計算結果,看看他們的耗時。

1. 處理要求:

一個Excel表格中包含了3萬條記錄,其中B,C兩個列記錄了某些計算值,讀取前一萬行記錄,將這兩個列的差值進行計算,然后匯總得出差的和。

文件是這個樣子:Book300s.xlsx 。

2. 處理方式有以下3種,我們對比一下耗時的大小。

處理方式 代碼名稱
1. 使用Python的xlwings類庫,讀取Excel文件,然后采用Excel的Sheet和Range的引用方式讀取并計算 XLS_READ_SHEET.py
2. 直接使用Excel自帶的VBA語言進行計算 VBA

3. 使用Python的xlwings類庫,讀取Excel文件,然后采用Python的自帶數據類型List列表進行數據存儲和計算

XLS_READ_LIST.py

3. 首先測試第一種,XLS_READ_SHEET.py

使用Python的xlwings類庫,讀取Excel文件,然后引用Excel的Sheet和Range的方式來讀取并計算

#coding=utf-8
import xlwings as xw
import pandas as pd
import time

start_row = 2 # 處理Excel文件開始行
end_row = 10002 # 處理Excel結束行

#記錄打開表單開始時間
start_open_time = time.time()

#指定不顯示地打開Excel,讀取Excel文件
app = xw.App(visible=False, add_book=False)
wb = app.books.open('D:/PYTHON/TEST_CODE/Book300s.xlsx') # 打開Excel文件
sheet = wb.sheets[0] # 選擇第0個表單

#記錄打開Excel表單結束時間
end_open_time = time.time()

#記錄開始循環計算時間
start_run = time.time()

row_content = []
#讀取Excel表單前10000行的數據,Python的in range是左閉右開的,到10002結束,但區間只包含2到10001這一萬條
for row in range(start_row, end_row):
  row_str = str(row)
  #循環中引用Excel的sheet和range的對象,讀取B列和C列的每一行的值,對比計算
  start_value = sheet.range('B' + row_str).value
  end_value = sheet.range('C' + row_str).value
  if start_value = end_value:
    values = end_value - start_value
    #同時測試List數組添加記錄
    row_content.append(values)

#計算和
total_values = sum(row_content)

#記錄結束循環計算時間
end_run = time.time()
sheet.range('E2').value = str(total_values)
sheet.range('E3').value = '使用Sheet計算時間(秒):' + str(end_run - start_run)

#保存并關閉Excel文件
wb.save()
wb.close()

print ('結果總和:', total_values)
print ('打開并讀取Excel表單時間(秒):',  end_open_time - start_open_time)
print ('計算時間(秒):',  end_run - start_run)
print ('處理數據條數:' , len(row_content))

用Python直接訪問Sheet和Range取值的計算結果如下:

讀取Excel文件用時 4.47秒

處理Excel 10000 行數據花費了117秒的時間。

4. 然后我們用Excel自帶的VBA語言來處理一下相同的計算。也是直接引用Sheet,Range等Excel對象,但VBA的數組功能實在是不好用,就不測試添加數組了。

Option Explicit

Sub VBA_CAL_Click()
  Dim i_count As Long
  Dim offset_value, total_offset_value As Double
  Dim st, et As Date
  st = Time()

  i_count = Sheets("Sheet1").Cells(Rows.Count, 1).End(xlUp).Row
  i_count = 10001
  For i_count = 2 To i_count
     If Range("C"  i_count).Value > Range("B"  i_count).Value Then
       offset_value = Range("C"  i_count).Value - Range("B"  i_count).Value
       total_offset_value = total_offset_value + offset_value
     End If
  Next i_count

  et = Time()
  Range("E2").Value = total_offset_value
  Range("E3").Value = et - st

  MsgBox "Result: "  total_offset_value  Chr(10)  "Running time: "  et - st
End Sub

VBA處理計算結果如下:

保存了3萬條數據的Excel文件是通過手工打開的,在電腦上大概花費了8.2秒的時間

處理Excel 前10000行數據花費了1.16秒的時間。

5.使用Python的xlwings類庫,讀取Excel文件,然后采用Python的自帶數據類型List進行數據存儲和計算,計算完成后再將結果寫到Excel表格中

#coding=utf-8
import xlwings as xw
import pandas as pd
import time

#記錄打開表單開始時間
start_open_time = time.time()

#指定不顯示地打開Excel,讀取Excel文件
app = xw.App(visible=False, add_book=False)
wb = app.books.open('D:/PYTHON/TEST_CODE/Book300s.xlsx') # 打開Excel文件
sheet = wb.sheets[0] # 選擇第0個表單

#記錄打開Excel表單結束時間
end_open_time = time.time()

#記錄開始循環計算時間
start_run = time.time()

row_content = []
#讀取Excel表單前10000行的數據,并計算B列和C列的差值之和
list_value = sheet.range('A2:D10001').value
for i in range(len(list_value)):
   #使用Python的類庫直接訪問Excel的表單是很緩慢的,不要在Python的循環中引用sheet等Excel表單的單元格,
   #而是要用List一次性讀取Excel里的數據,在List內存中計算好了,然后返回結果
   start_value = list_value[i][1]
   end_value = list_value[i][2]
   if start_value = end_value:
     values = end_value- start_value
     #同時測試List數組添加記錄
     row_content.append(values)

#計算和
total_values = sum(row_content)
#記錄結束循環計算時間
end_run = time.time()
sheet.range('E2').value = str(total_values)
sheet.range('E3').value = '使用List 計算時間(秒):' + str(end_run - start_run)

#保存并關閉Excel文件
wb.save()
wb.close()

print ('結果總和:', total_values)
print ('打開并讀取Excel表單時間(秒):',  end_open_time - start_open_time)
print ('計算時間(秒):',  end_run - start_run)
print ('處理數據條數:' , len(row_content))

用Python的LIST在內存中計算結果如下:

讀取Excel文件用時 4.02秒

處理Excel 10000 行數據花費了 0.10 秒的時間。

6 結論:

Python操作Excel的類庫有以往有 xlrd、xlwt、openpyxl、pyxll等,這些類庫有的只支持讀取,有的只支持寫入,并且有的不支持Excel的xlsx格式等。

所以我們采用了最新的開源免費的xlwings類庫,xlwings能夠很方便的讀寫Excel文件中的數據,并支持Excel的單元格格式修改,也可以與pandas等類庫集成使用。

VBA是微軟Excel的原生二次開發語言,是辦公和數據統計的利器,在金融,統計,管理,計算中應用非常廣泛,但是VBA計算能力較差,支持的數據結構少,編輯器粗糙。

雖然VBA有很多不足,但是VBA的宿主Office Excel卻是天才程序員基于C++開發的作品,穩定,高效,易用 。

有微軟加持,VBA雖然數據結構少,運行速度慢,但訪問自己Excel的Sheet,Range,Cell等對象卻速度飛快,這就是一體化產品的優勢。

VBA讀取Excel的Range,Cell等操作是通過底層的API直接讀取數據的,而不是通過微軟統一的外部開發接口。所以Python的各種開源和商用的Excel處理類庫如果和VBA來比較讀寫Excel格子里面的數據,都是處于劣勢的(至少是不占優勢的),例子2的VBA 花費了1.16秒就能處理完一萬條數據。

Python基于開源,語法優美而健壯,支持面向對象開發,最重要的是,Python有豐富而功能強大的類庫,支持多種工作場景的開發。

我們應該認識到,Excel對于Python而言,只是數據源文件的一種,當處理大量數據時,Python處理Excel就要把Excel當數據源來處理,一次性地讀取數據到Python的數據結構中,而不是大量調用Excel里的對象,不要說頻繁地寫入Excel,就是頻繁地讀取Excel里面的某些單元格也是效率較低的。例子1的Python頻繁讀取Sheet,Range數據,結果花費了117秒才處理完一萬條數據。

Python的計算效率和數據結構的操作方便性可比VBA強上太多,和VBA聯合起來使用,各取所長是個好主意。

當Excel數據一次性讀入Python的內存List數據結構中,然后基于自身的List數據結構在內存中計算,例子3的Python只用了 0.1秒就完成了一萬條數據的計算并將結果寫回Excel。

總結:

處理方式-計算Excel里的一萬條記錄的差值的總和 效率
1. 使用Python的xlwings類庫,采用Excel的Sheet和Range的引用方式,按行讀取Excel文件的記錄并計算 差,計算用時 117秒
2. 直接使用Excel自帶的VBA語言進行計算,也是采用Excel的Sheet和Range的引用方式,按行讀取Excel文件的記錄并計算 很高 ,計算用時 1.16秒

3. 使用Python的xlwings類庫,一次性讀取Excel文件中的數據到Python的List數據結構中,然后在Python的List列表中進行數據存儲和計算

最高,計算用時 0.1秒     

到此這篇關于淺談Python xlwings 讀取Excel文件的正確姿勢的文章就介紹到這了,更多相關Python xlwings 讀取Excel內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 如何用python合并多個excel文件
  • python合并多個excel文件的示例
  • 使用python將多個excel文件合并到同一個文件的方法
  • 使用Python橫向合并excel文件的實例
  • Python批量合并有合并單元格的Excel文件詳解
  • Python將多個excel文件合并為一個文件
  • 使用Python快速打開一個百萬行級別的超大Excel文件的方法
  • Python3利用openpyxl讀寫Excel文件的方法實例
  • 基于Python的接口自動化讀寫excel文件的方法
  • python基于openpyxl生成excel文件
  • Python xlrd/xlwt 創建excel文件及常用操作
  • 教你用Python代碼實現合并excel文件

標簽:隨州 興安盟 濟源 昭通 信陽 淘寶好評回訪 阜新 合肥

巨人網絡通訊聲明:本文標題《淺談Python xlwings 讀取Excel文件的正確姿勢》,本文關鍵詞  淺談,Python,xlwings,讀取,Excel,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《淺談Python xlwings 讀取Excel文件的正確姿勢》相關的同類信息!
  • 本頁收集關于淺談Python xlwings 讀取Excel文件的正確姿勢的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    日本韩国欧美国产| 亚洲午夜一区二区| 国产一区二区三区在线看麻豆| 欧美三级视频在线观看| 亚洲欧美日韩在线不卡| 97国产精品videossex| 国产精品婷婷午夜在线观看| 高清在线不卡av| 色诱视频网站一区| 国产亚洲精品中文字幕| 国产一区二区精品在线观看| 2023国产精品视频| 精品一区二区精品| 久久午夜老司机| 国产成a人亚洲精品| 国产精品久久三| 91色九色蝌蚪| 一区二区三区.www| 7777精品伊人久久久大香线蕉最新版| 日韩精品久久久久久| 欧美一区二区视频观看视频| 麻豆精品一区二区| 久久午夜色播影院免费高清| 欧美日韩精品二区第二页| 偷拍一区二区三区| 精品少妇一区二区三区在线播放| 国精产品一区一区三区mba桃花 | 国产精品国产三级国产| av在线播放成人| 亚洲色欲色欲www在线观看| 欧洲精品在线观看| 五月婷婷综合网| 日韩美女视频在线| 国产.欧美.日韩| 亚洲欧美日本在线| 欧美日韩国产123区| 精品一区二区三区免费播放| 久久综合久久综合亚洲| 久久久国产精品麻豆| 国产成人在线色| 专区另类欧美日韩| 欧美精品自拍偷拍| 国产自产高清不卡| 中文字幕一区二区三| 欧美性生活久久| 久久99精品久久久久久国产越南| 久久久久国产精品麻豆ai换脸 | 亚洲成人av电影| 日韩欧美亚洲国产精品字幕久久久| 国产精品正在播放| 一区二区在线观看免费 | 欧美日韩在线不卡| 老司机午夜精品| 日韩伦理免费电影| 在线电影院国产精品| 国产成人精品网址| 一区二区不卡在线播放| 精品国产凹凸成av人导航| a亚洲天堂av| 美女视频免费一区| 亚洲欧美电影院| 日韩免费看的电影| 91视频.com| 久久99精品国产麻豆不卡| 中文字幕一区二区三区四区| 777午夜精品视频在线播放| 国产河南妇女毛片精品久久久| 亚洲电影第三页| 中文字幕久久午夜不卡| 欧美一区二区网站| a在线欧美一区| 久久成人18免费观看| 亚洲精品精品亚洲| 亚洲精品一区二区三区福利 | 日韩欧美第一区| 99久久国产免费看| 激情综合色综合久久| 一区二区三区国产豹纹内裤在线| 欧美tk丨vk视频| 欧美做爰猛烈大尺度电影无法无天| 国产乱子伦视频一区二区三区 | 欧美性一二三区| 福利一区在线观看| 三级久久三级久久| 亚洲色图视频网站| 久久久久久久久99精品| 91.com视频| 日本韩国精品在线| 成人免费视频caoporn| 美女一区二区在线观看| 亚洲激情在线激情| 国产精品热久久久久夜色精品三区 | 成人激情免费网站| 精品一区中文字幕| 视频在线观看一区二区三区| 国产精品欧美极品| 久久久午夜精品| 日韩欧美专区在线| 欧美人动与zoxxxx乱| 色狠狠一区二区| a亚洲天堂av| 国产传媒久久文化传媒| 久久99久久久欧美国产| 香蕉久久一区二区不卡无毒影院 | 99热在这里有精品免费| 国产成人免费高清| 久久99精品国产麻豆不卡| 日韩精品乱码av一区二区| 一区二区三区在线观看欧美| 国产精品久久久久三级| 久久精品人人做人人爽97| 欧美一区二区三区免费观看视频 | 色悠悠久久综合| a在线欧美一区| 成人黄色免费短视频| 国产白丝精品91爽爽久久| 国产福利视频一区二区三区| 激情六月婷婷综合| 韩国av一区二区三区在线观看| 免费av成人在线| 日韩高清在线一区| 欧美亚洲综合久久| 国产麻豆午夜三级精品| 久久精品国产亚洲a| 日韩高清在线一区| 奇米色一区二区| 秋霞av亚洲一区二区三| 日本美女一区二区三区| 日本不卡一区二区三区 | 五月婷婷久久综合| 亚洲成人在线观看视频| 亚洲综合激情网| 亚洲国产另类精品专区| 亚洲大片一区二区三区| 三级成人在线视频| 另类专区欧美蜜桃臀第一页| 麻豆成人av在线| 寂寞少妇一区二区三区| 国产激情一区二区三区| 波多野结衣在线一区| 99热99精品| 欧美中文字幕一区二区三区亚洲| 欧美午夜影院一区| 欧美丰满少妇xxxbbb| 日韩一级片网址| 久久久精品天堂| 中文一区二区在线观看| 日韩理论片网站| 一区二区三区四区乱视频| 午夜视频在线观看一区二区三区| 天堂蜜桃91精品| 精品综合久久久久久8888| 国产东北露脸精品视频| 成人av网站在线| 欧洲亚洲国产日韩| 在线成人免费观看| 精品久久久久久综合日本欧美| 国产视频视频一区| 亚洲人成在线观看一区二区| 亚洲一区二区三区爽爽爽爽爽| 日本不卡不码高清免费观看| 国产一区二区三区不卡在线观看 | 丁香啪啪综合成人亚洲小说| 97精品电影院| 4438亚洲最大| 国产欧美一区视频| 亚洲男人的天堂在线观看| 视频一区免费在线观看| 国产精品一区二区无线| 99re这里只有精品6| 欧美裸体一区二区三区| www国产精品av| 色综合 综合色| 欧美日韩综合不卡| 精品国内二区三区| 国产精品国产三级国产三级人妇 | 午夜精品一区二区三区三上悠亚| 日韩电影在线观看一区| 国产精品1区二区.| 91黄视频在线| 久久婷婷久久一区二区三区| 亚洲欧美一区二区久久 | 国产中文一区二区三区| 91香蕉国产在线观看软件| 91麻豆精品国产91久久久久久久久 | 亚洲综合在线五月| 精久久久久久久久久久| 91麻豆.com| 日韩精品一区二区三区中文精品| 国产精品女主播av| 日韩二区在线观看| 成人国产精品免费观看| 欧美一卡在线观看| 成人欧美一区二区三区黑人麻豆| 视频在线在亚洲| 91色porny| 久久久影院官网| 日韩精品亚洲一区| 色综合一区二区| 久久精品欧美一区二区三区不卡|