婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

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

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

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

1. 處理要求:

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

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

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

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

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

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結(jié)束行

#記錄打開表單開始時間
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表單結(jié)束時間
end_open_time = time.time()

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

row_content = []
#讀取Excel表單前10000行的數(shù)據(jù),Python的in range是左閉右開的,到10002結(jié)束,但區(qū)間只包含2到10001這一萬條
for row in range(start_row, end_row):
  row_str = str(row)
  #循環(huán)中引用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數(shù)組添加記錄
    row_content.append(values)

#計算和
total_values = sum(row_content)

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

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

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

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

讀取Excel文件用時 4.47秒

處理Excel 10000 行數(shù)據(jù)花費了117秒的時間。

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

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處理計算結(jié)果如下:

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

處理Excel 前10000行數(shù)據(jù)花費了1.16秒的時間。

5.使用Python的xlwings類庫,讀取Excel文件,然后采用Python的自帶數(shù)據(jù)類型List進(jìn)行數(shù)據(jù)存儲和計算,計算完成后再將結(jié)果寫到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表單結(jié)束時間
end_open_time = time.time()

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

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

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

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

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

用Python的LIST在內(nèi)存中計算結(jié)果如下:

讀取Excel文件用時 4.02秒

處理Excel 10000 行數(shù)據(jù)花費了 0.10 秒的時間。

6 結(jié)論:

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

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

VBA是微軟Excel的原生二次開發(fā)語言,是辦公和數(shù)據(jù)統(tǒng)計的利器,在金融,統(tǒng)計,管理,計算中應(yīng)用非常廣泛,但是VBA計算能力較差,支持的數(shù)據(jù)結(jié)構(gòu)少,編輯器粗糙。

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

有微軟加持,VBA雖然數(shù)據(jù)結(jié)構(gòu)少,運行速度慢,但訪問自己Excel的Sheet,Range,Cell等對象卻速度飛快,這就是一體化產(chǎn)品的優(yōu)勢。

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

Python基于開源,語法優(yōu)美而健壯,支持面向?qū)ο箝_發(fā),最重要的是,Python有豐富而功能強大的類庫,支持多種工作場景的開發(fā)。

我們應(yīng)該認(rèn)識到,Excel對于Python而言,只是數(shù)據(jù)源文件的一種,當(dāng)處理大量數(shù)據(jù)時,Python處理Excel就要把Excel當(dāng)數(shù)據(jù)源來處理,一次性地讀取數(shù)據(jù)到Python的數(shù)據(jù)結(jié)構(gòu)中,而不是大量調(diào)用Excel里的對象,不要說頻繁地寫入Excel,就是頻繁地讀取Excel里面的某些單元格也是效率較低的。例子1的Python頻繁讀取Sheet,Range數(shù)據(jù),結(jié)果花費了117秒才處理完一萬條數(shù)據(jù)。

Python的計算效率和數(shù)據(jù)結(jié)構(gòu)的操作方便性可比VBA強上太多,和VBA聯(lián)合起來使用,各取所長是個好主意。

當(dāng)Excel數(shù)據(jù)一次性讀入Python的內(nèi)存List數(shù)據(jù)結(jié)構(gòu)中,然后基于自身的List數(shù)據(jù)結(jié)構(gòu)在內(nèi)存中計算,例子3的Python只用了 0.1秒就完成了一萬條數(shù)據(jù)的計算并將結(jié)果寫回Excel。

總結(jié):

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

3. 使用Python的xlwings類庫,一次性讀取Excel文件中的數(shù)據(jù)到Python的List數(shù)據(jù)結(jié)構(gòu)中,然后在Python的List列表中進(jìn)行數(shù)據(jù)存儲和計算

最高,計算用時 0.1秒     

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

您可能感興趣的文章:
  • 如何用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 創(chuàng)建excel文件及常用操作
  • 教你用Python代碼實現(xiàn)合并excel文件

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《淺談Python xlwings 讀取Excel文件的正確姿勢》,本文關(guān)鍵詞  淺談,Python,xlwings,讀取,Excel,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《淺談Python xlwings 讀取Excel文件的正確姿勢》相關(guān)的同類信息!
  • 本頁收集關(guān)于淺談Python xlwings 讀取Excel文件的正確姿勢的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    亚洲不卡在线观看| 国产成人在线网站| 久草在线在线精品观看| 91原创在线视频| 久久综合狠狠综合| 亚洲一区中文日韩| 粗大黑人巨茎大战欧美成人| 日韩三级伦理片妻子的秘密按摩| 亚洲伦在线观看| 国产成人精品免费视频网站| 欧美mv日韩mv国产网站app| 亚洲一区日韩精品中文字幕| a在线欧美一区| 国产日韩精品视频一区| 蜜臀av性久久久久蜜臀aⅴ| 欧洲国产伦久久久久久久| 中文在线免费一区三区高中清不卡| 蜜臀久久99精品久久久久久9 | 欧美草草影院在线视频| 夜夜揉揉日日人人青青一国产精品| 成人小视频在线| 国产片一区二区| 国产精品一区二区不卡| 精品国偷自产国产一区| 蜜桃91丨九色丨蝌蚪91桃色| 7777精品伊人久久久大香线蕉的 | 欧美在线三级电影| 中文字幕精品一区二区精品绿巨人 | 国产精品一区免费在线观看| 亚洲色图欧洲色图| 不卡区在线中文字幕| 久久丝袜美腿综合| 国产一区二三区好的| 久久久夜色精品亚洲| 国产一区二区在线观看免费| 精品国产凹凸成av人网站| 久久99精品一区二区三区| 精品国产第一区二区三区观看体验 | 国内偷窥港台综合视频在线播放| 日韩一区二区三区电影在线观看| 日韩av电影免费观看高清完整版在线观看 | 日本久久电影网| 亚洲国产精品一区二区久久恐怖片| 欧美日韩一区成人| 日韩专区中文字幕一区二区| 欧美不卡一区二区三区四区| 国产成+人+日韩+欧美+亚洲| 综合久久给合久久狠狠狠97色 | 日韩av电影免费观看高清完整版 | 色域天天综合网| 亚洲一区二区三区四区五区黄| 欧美亚州韩日在线看免费版国语版| 亚洲va欧美va天堂v国产综合| 91精品国产综合久久精品图片| 精品系列免费在线观看| 国产丝袜欧美中文另类| 一本久久综合亚洲鲁鲁五月天| 亚洲综合在线电影| 日韩欧美的一区| 国产精品1区二区.| 亚洲综合激情网| 精品成人在线观看| 色中色一区二区| 久久99久久99小草精品免视看| 国产精品久久久久四虎| 欧美日韩成人综合在线一区二区| 国产精一品亚洲二区在线视频| 亚洲男同性视频| 日韩亚洲欧美中文三级| 成人高清免费观看| 日韩精品国产精品| 国产精品免费视频一区| 欧美一区二区免费视频| 91亚洲精品久久久蜜桃| 久久精品国产免费| 一区二区三区毛片| 久久久亚洲欧洲日产国码αv| 在线观看日韩精品| 高清国产一区二区三区| 日韩av成人高清| 亚洲一区精品在线| 欧美激情一区二区三区不卡| 日韩欧美在线网站| 欧美中文字幕亚洲一区二区va在线| 国产成人精品影视| 蜜桃免费网站一区二区三区| 亚洲一区二区高清| 中文字幕佐山爱一区二区免费| 亚洲精品在线电影| 欧美日韩国产免费一区二区| 91麻豆高清视频| 成人91在线观看| 国产精品一区专区| 免费在线成人网| 偷拍亚洲欧洲综合| 亚洲图片自拍偷拍| 亚洲老司机在线| 最新久久zyz资源站| 亚洲国产精品av| 国产亚洲精品福利| 精品久久一二三区| 日韩一级黄色片| 日韩视频123| 日韩一区二区不卡| 欧美巨大另类极品videosbest | 欧美三级韩国三级日本一级| 91蜜桃免费观看视频| 成人av动漫网站| 99麻豆久久久国产精品免费| 国产v日产∨综合v精品视频| 国产成人精品亚洲午夜麻豆| 国产成人午夜精品5599| 国产宾馆实践打屁股91| 国产成人一级电影| 成人精品gif动图一区| 成人app软件下载大全免费| 国产精品中文有码| 国产91精品一区二区麻豆亚洲| 国产麻豆精品一区二区| 国产最新精品免费| 国产91精品久久久久久久网曝门 | 韩国一区二区视频| 国产综合色在线| 国产精品自拍三区| 成人性生交大片免费看视频在线| 成人激情综合网站| 欧美自拍偷拍一区| 6080午夜不卡| 26uuu色噜噜精品一区| 国产三级欧美三级日产三级99 | 欧美久久久久久久久| 日韩一区二区视频| 国产午夜亚洲精品理论片色戒 | 欧美本精品男人aⅴ天堂| 久久嫩草精品久久久精品| 国产精品色眯眯| 亚洲国产精品自拍| 九色porny丨国产精品| 成人av在线一区二区三区| 欧美视频中文字幕| 精品国产一区二区三区久久影院| 亚洲国产精品ⅴa在线观看| 洋洋av久久久久久久一区| 久久精品国产精品亚洲红杏| 99re亚洲国产精品| 7777女厕盗摄久久久| 国产精品美女久久久久av爽李琼 | 一区二区三区美女视频| 日本欧美一区二区三区| 国产激情视频一区二区在线观看 | 欧美r级电影在线观看| 最新日韩av在线| 日韩av在线发布| 成人午夜在线视频| 宅男噜噜噜66一区二区66| 国产精品乱码一区二区三区软件 | 国精产品一区一区三区mba桃花| 成人免费视频免费观看| 欧美日韩成人激情| 国产精品素人一区二区| 男人的天堂亚洲一区| 91丨九色丨蝌蚪富婆spa| 欧美大片免费久久精品三p| 一区二区欧美精品| 福利一区在线观看| 欧美一区二区三区免费在线看 | 成人欧美一区二区三区白人| 久久电影国产免费久久电影 | 久久99国产精品尤物| 欧美自拍偷拍午夜视频| 中文字幕一区二区三区在线不卡 | 国产精品久久久久久久蜜臀| 日本女优在线视频一区二区| 在线精品视频免费播放| 亚洲国产高清在线观看视频| 久久精品免费观看| 欧美日韩久久一区二区| 一区二区三区在线视频播放| 成人av在线资源网站| 国产亚洲一区二区在线观看| 九九视频精品免费| 日韩一区二区三区电影在线观看 | 一区二区三区在线视频观看58| 国产精品伊人色| 欧美精品一区二区高清在线观看 | 五月天视频一区| 色域天天综合网| 亚洲免费观看高清在线观看| av亚洲产国偷v产偷v自拍| 国产午夜精品福利| 国产资源精品在线观看| 久久综合网色—综合色88| 日本不卡一区二区三区| 欧美日韩成人激情| 五月天久久比比资源色| 欧美精品第一页| 免费av网站大全久久| 日韩欧美一级二级三级| 久久99久久久欧美国产| 国产亚洲成aⅴ人片在线观看|