python使用列表的最佳方案
經(jīng)常寫Python程序的人,列表應(yīng)該是使用率最高數(shù)據(jù)結(jié)構(gòu)的了。我們使用列表的過程中,生成列表方式有很多種,哪一種方式性能是最好的呢?可能很多人都沒有關(guān)心過這個(gè)問題。假設(shè)要生成一個(gè)有1000個(gè)元素的列表。采用下面哪一種方式生成最好呢?
1、連接方式
def gen_list1(): l = [] for i in range(1000): l = l + [i]
2、append方法
def gen_list2(): l = [] for i in range(1000): l.append(i)
3、列表表達(dá)式
def gen_list3(): l = [i for i in range(1000)]
4、range函數(shù)
def gen_list4(): l = list(range(1000))
以上四種方式,都可以實(shí)現(xiàn)一個(gè)有1000個(gè)元素的列表。為了知道哪一種方式耗時(shí)最少,我們需要進(jìn)行測試才可以知曉。測試耗時(shí)我們使用Timer方法,下面編寫具體測試代碼。
from timeit import Timer t1 = Timer("gen_list1()", "from __main__ import gen_list1") print("連接方式:", t1.timeit(number=1000), "ms") t2 = Timer("gen_list2()", "from __main__ import gen_list2") print("append方法:", t2.timeit(number=1000), "ms") t3 = Timer("gen_list3()", "from __main__ import gen_list3") print("列表表達(dá)式:", t3.timeit(number=1000), "ms") t4 = Timer("gen_list4()", "from __main__ import gen_list4") print("range函數(shù):", t4.timeit(number=1000), "ms")
測試程序編寫完成后,可以運(yùn)行看看結(jié)果。
連接方式: 1.2728083460242487 ms
append方法: 0.10177052899962291 ms
列表表達(dá)式: 0.03995161800412461 ms
range函數(shù): 0.01611424400471151 ms
通過測試我們可以看出來,使用range函數(shù)生成1000個(gè)元素列表,耗時(shí)是最少的。要想寫出高性能Python程序,掌握分析程序性能的方法和熟悉每一種數(shù)據(jù)結(jié)構(gòu)都是非常重要的技能。
以上就是python使用列表的最佳方案的詳細(xì)內(nèi)容,更多關(guān)于python列表的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python 解決pycharm運(yùn)行py文件只有unittest選項(xiàng)的問題
這篇文章主要介紹了python 解決pycharm運(yùn)行py文件只有unittest選項(xiàng)的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09Python多線程通信queue隊(duì)列用法實(shí)例分析
這篇文章主要介紹了Python多線程通信queue隊(duì)列用法,結(jié)合實(shí)例形式分析了Python多線程通信queue隊(duì)列相關(guān)概念、原理、用法及操作注意事項(xiàng),需要的朋友可以參考下2020-03-03在Python的Flask框架中實(shí)現(xiàn)單元測試的教程
這篇文章主要介紹了在Python的Flask框架中實(shí)現(xiàn)單元測試的教程,屬于自動(dòng)化部署的方面,可以給debug工作帶來諸多便利,需要的朋友可以參考下2015-04-0414個(gè)用Python實(shí)現(xiàn)的Excel常用操作總結(jié)
自從學(xué)了Python后就逼迫自己不用Excel,所有操作用Python實(shí)現(xiàn)。目的是鞏固Python,與增強(qiáng)數(shù)據(jù)處理能力。本文為大家總結(jié)了14個(gè)用Python實(shí)現(xiàn)的Excel常用操作,需要的可以參考一下2022-06-06Python算法應(yīng)用實(shí)戰(zhàn)之棧詳解
棧是什么,你可以理解為一種先入后出的數(shù)據(jù)結(jié)構(gòu)(First In Last Out),一種操作受限的線性表。下面這篇文章主要給大家介紹了Python中棧的應(yīng)用實(shí)戰(zhàn),文中給出了多個(gè)實(shí)例,需要的朋友可以參考借鑒,下面來一起看看吧。2017-02-02