色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

python迭代調用內置函數計時比較(下)

jf_78858299 ? 來源:梯閱線條小梯子 ? 作者:小梯子 ? 2023-02-21 14:56 ? 次閱讀

1.3 python迭代工具最小計時

描述

timertool.py:

timer_compatible():根據win版、Unix版、python版本選擇對應計時函數計算總時間。

mintime():計算每個迭代工具執行的最小時間。

timeiterevn.py:

timeiter_compatible():計算每個迭代工具執行的總時間、平均時間、最小時間。

示例

#timertool.py
import time,sys
reps = 1000
repslist = range(reps)

if sys.version[:3]<'3.3':
   if sys.platform[:3] == 'win':
       timefunc = time.clock
   else:
       timefunc = time.time
else:
   timefunc = time.perf_counter
   
def trace(*args):
   #print('args={}'.format(args))
   pass

def timer(func,*pargs,**kargs):
   begin = time.perf_counter()
   for i in repslist:
       ret = func(*pargs,**kargs)
   usetime = time.perf_counter() - begin
   return (usetime,ret)

def timer_compatible(func,*pargs,**kargs):
   _reps = kargs.pop('_reps',1000)
   trace(func,pargs,kargs,_reps)
   repslist = range(_reps)
   begin = timefunc()
   for i in repslist:
       ret = func(*pargs,**kargs)
   usetime = timefunc() - begin
   return (usetime,ret)
   
def mintime(func,*pargs,**kargs):
   _reps = kargs.pop('_reps',50)
   mintime = 2 ** 32
   for i in range(_reps):
      (usetime,ret) = timer_compatible(func,*pargs,_reps=1,**kargs)
       if usetime < mintime:
           mintime = usetime
   return (mintime,ret)
   
# timeiterevn.py
import sys,timertool
s = '梯閱線條tyxt'*1000

def forloop():
   res = []
   for x in s:
       res.append(ord(x)+1)
   return res
   
def listComp():
   return [ord(x) for x in s]

def mapCall():
   return list(map(lambda x:ord(x)+1,s))
   
def genExpr():
   return list(ord(x)+1 for x in s)
   
def genFunc():
   def gen():
       for x in s:
           yield ord(x)+1
   return list(gen())
def commstr(s):
   commstr = '# '+s
   print(commstr)
functp = (forloop,listComp,mapCall,genExpr,genFunc)
timetp = (timertool.timer_compatible,timertool.mintime)
commstr('-'*33)
commstr(str(sys.version))
def timeiter():
   reslist=[]
   for test in funcList:
       usetime,result = timertool.timer(test)
       reslist.append((test.__name__,usetime,result[0],result[-1],len(result)))

   commstr('-'*33)        
   reslistsort=sorted(reslist,key = lambda x:x[1])
   for L in reslistsort:
       #print(commstr+'%-9s:%.5f=>[%s....%s....%s]'%(L[0],L[1],L[2],L[3],L[4]))
       commstr('%-9s:%.5f=>[%s....%s....%s]'%(L[0],L[1],L[2],L[3],L[4]))
   commstr('-'*33)  

def timeiter_compatible():
   _reps = 1000
   commstr('-'*33)
   for ttp in timetp:
       reslist=[]
       commstr('<{}>'.format(ttp.__name__))
       for ftp in functp:
           usetime,result = ttp(ftp,_reps=_reps)
           reslist.append((ftp.__name__,usetime,result[0],result[-1],len(result)))
       commstr('-'*33)
       reslistsort=sorted(reslist,key = lambda x:x[1])
       if ttp.__name__ == 'timer_compatible':
           commstr('總時間排序')
       else:
           commstr('最小時間排序')
       commstr('-'*33)
       for L in reslistsort:
           commstr('%-9s:%.5f=>[%s....%s....%s]'%(L[0],L[1],L[2],L[3],L[4]))
       commstr('-'*33)
       if ttp.__name__ == 'timer_compatible':
           commstr('平均時間排序')
           commstr('-'*33)
           for L in reslistsort:
               commstr('%-9s:%.5f=>[%s....%s....%s]'%(L[0],(L[1]/_reps),L[2],L[3],L[4]))
           commstr('-'*33)
timeiter_compatible()

# ---------------------------------
# 3.7.8 (tags/v3.7.8:4b47a5b6ba, Jun 28 2020, 07:55:33) [MSC v.1916 32 bit (Intel)]
# ---------------------------------
# 
# ---------------------------------
# 總時間排序
# ---------------------------------
# listComp :0.52310=>[26799....116....8000]
# genFunc :0.92414=>[26800....117....8000]
# genExpr :0.94791=>[26800....117....8000]
# forloop :1.01522=>[26800....117....8000]
# mapCall :1.12953=>[26800....117....8000]
# ---------------------------------
# 平均時間排序
# ---------------------------------
# listComp :0.00052=>[26799....116....8000]
# genFunc :0.00092=>[26800....117....8000]
# genExpr :0.00095=>[26800....117....8000]
# forloop :0.00102=>[26800....117....8000]
# mapCall :0.00113=>[26800....117....8000]
# ---------------------------------
# 
# ---------------------------------
# 最小時間排序
# ---------------------------------
# listComp :0.00039=>[26799....116....8000]
# genFunc :0.00065=>[26800....117....8000]
# genExpr :0.00066=>[26800....117....8000]
# forloop :0.00072=>[26800....117....8000]
# mapCall :0.00073=>[26800....117....8000]
# ---------------------------------

1.4 time計時

描述

python的time模塊對Windows、Unix、python版本提供不同計時方法。

NO 系統版本 對應方法
1 Windows time.clock()
2 Unix time.time()
3 =python3.8 time.perf_counter(),python3.3開始支持

兩次調用之間的時間差用于計時。

示例

>>> import time
>>> begin = time.clock()
>>> end = time.clock()
>>> use=end - begin
>>> begin,end,use
(782.9449924, 793.3414938, 10.39650139999992)
>>> begin = time.time()
>>> end = time.time()
>>> use = end - begin
>>> begin,end,use
(1674368678.73148, 1674368685.6409733, 6.909493446350098)
>>> begin = time.perf_counter()
>>> end = time.perf_counter()
>>> use = end - begin
>>> begin,end,use
(899.3102242, 908.7626699, 9.452445699999998)

1.5 sys平臺版本

描述

python通過sys模塊獲取平臺版本信息

NO 屬性 描述
1 sys.version python版本
2 sys.platform 系統平臺

示例

>>> import sys
>>> v=sys.version
>>> pf=sys.platform
>>> v
'3.7.8 (tags/v3.7.8:4b47a5b6ba, Jun 28 2020, 07:55:33) [MSC v.1916 32 bit (Intel)]'
>>> pf
'win32'
>>> v[:3],pf[:3]
('3.7', 'win')

1.6 sorted按鍵排序

用法

sorted(iterable, /, *, key=None, reverse=False)

描述

python內置函數sorted(可迭代對象,key)屬于迭代工具,按指定key對可迭代對象進行排序。

key:自定義排序函數。

reverse:默認False為升序。

示例

>>> zs={'name':'張三','yuwen':90,'shuxue':100,'english':60}
>>> ls={'name':'李四','yuwen':91,'shuxue':95,'english':85}
>>> ww={'name':'王五','yuwen':80,'shuxue':99,'english':82}
>>> classOne=[zs,ls,ww]
>>> for i,stu in zip(range(1,len(classOneSort)+1),classOneSort):
   zf = stu['yuwen']+stu['shuxue']+stu['english']
   print("總分第{i:0>3}名:{d[name]:>4},語文={d[yuwen]:>3},數學={d[shuxue]:>3},英語={d[english]:>3},總分={zf:>3}".format(d=stu,zf=zf,i=i))

   
總分第001名:  李四,語文= 91,數學= 95,英語= 85,總分=271
總分第002名:  王五,語文= 80,數學= 99,英語= 82,總分=261
總分第003名:  張三,語文= 90,數學=100,英語= 60,總分=250
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 生成器
    +關注

    關注

    7

    文章

    319

    瀏覽量

    21082
  • python
    +關注

    關注

    56

    文章

    4807

    瀏覽量

    84956
  • for循環
    +關注

    關注

    0

    文章

    61

    瀏覽量

    2530
收藏 人收藏

    評論

    相關推薦

    關于Python巧妙而強大的內置函數

    python內置了一些非常巧妙而且強大的內置函數,對初學者來說,一般不怎么用到,我也是用了一段時間python之后才發現,哇還有這么好的
    發表于 12-14 14:52 ?546次閱讀
    關于<b class='flag-5'>Python</b>巧妙而強大的<b class='flag-5'>內置</b><b class='flag-5'>函數</b>

    一文詳解python調用函數

    函數被定義后,本身是不會自動執行的,只有在被調用后,函數才會被執行,得到相應的結果。但是在 Python 中我們要注意一個關鍵點,就是Python
    發表于 10-01 10:45 ?713次閱讀

    快速掌握Python的遞歸函數與匿名函數調用

    函數Python技術學習中重要的一個環節,深入掌握該階段的知識內容,對于Python技術能力的提升非常有幫助,這里就針對遞歸函數與匿名函數
    發表于 07-19 16:22

    python迭代

    的,哪些是不可迭代的。但是對新手來說,可能需要借助一些函數來判別,比如 Python 內置的 collections.abc 模塊,這個模塊只有在
    發表于 02-24 15:42

    python內置函數詳細資料概述

    本文檔的主要內容詳細介紹的是python內置函數詳細資料概述。
    發表于 11-18 08:00 ?0次下載

    python提供的68個內置函數詳解

    ? 內置函數就是Python給你提供的,拿來直接用的函數,比如print.,input等。 截止到python版本3.6.2 ,
    的頭像 發表于 10-27 09:14 ?2216次閱讀

    進階必備的68個Python 內置函數分析

    來源: pypypypy 內置函數就是Python給你提供的,拿來直接用的函數,比如print.,input等。 截止到python版本3.
    的頭像 發表于 11-01 10:18 ?4118次閱讀

    python迭代器詳解

    ] for i in alist:... print(i)...012345 2. 是否可迭代? 對 Python 比較熟悉的朋友,肯定知道哪些數據類型是可迭代的,哪些是不可
    的頭像 發表于 02-24 15:42 ?1367次閱讀

    Python支持遞歸函數

    Python支持遞歸函數——即直接或間接地調用自身以進行循環的函數。遞歸是頗為高級的話題,并且它在Python中相對少見。然而,它是一項應該
    的頭像 發表于 02-21 14:28 ?673次閱讀

    python迭代調用內置函數計時比較(上)

    python迭代工具自動調用迭代對象next方法,對迭代對象進行遍歷。 python的fo
    的頭像 發表于 02-21 14:56 ?651次閱讀

    python常用的內置函數和模塊

    python數字包含常用的內置函數和模塊,比如pow()、abs()、floor()、int()等函數,以及math、random等模塊。
    的頭像 發表于 03-10 10:10 ?971次閱讀

    python定義函數調用函數的順序

    定義函數調用函數的順序 函數被定義后,本身是不會自動執行的,只有在被調用后,函數才會被執行,得
    的頭像 發表于 10-04 17:17 ?1498次閱讀

    python函數函數之間的調用

    函數函數之間的調用 3.1 第一種情況 程序代碼如下: def x ( f ): def y (): print ( 1 ) return y def f (): print ( 2 )x(f
    的頭像 發表于 10-04 17:17 ?632次閱讀

    python調用math函數的方法

    Python編程中,數學函數是非常重要的工具,我們可以使用它們進行各種數值計算、幾何運算和統計分析等操作。Python的標準庫中內置了很多數學函數
    的頭像 發表于 11-22 11:01 ?3117次閱讀

    不屬于python內置函數

    Python是一種高級編程語言,它提供了許多內置函數,可以幫助開發人員更輕松地處理各種任務。但是,在Python中并非所有的函數都是
    的頭像 發表于 11-29 14:27 ?1567次閱讀
    主站蜘蛛池模板: 欧美性情一线免费http | 无限资源在线观看高清 | 日产久久视频 | 午夜特级毛片 | 正在播放国产尾随丝袜美女 | 久久成人伊人欧洲精品AV | 国产超碰人人爱被IOS解锁 | 妙玉被肉干高H潮文 | 久久re这里视频只精品首页 | 97在线观看成人免费视频 | 伊人久久电影网 | 好男人视频免费高清在线观看www | 伊人情人网综合 | 云南14学生真实初次破初视频 | 国产午夜精AV在线麻豆 | 欧美精品熟妇乱 | 欧美白人极品性喷潮 | 把英语老师强奷到舒服动态图 | 国产麻豆91网在线看 | 爽爽窝窝午夜精品一区二区 | 亚洲va久久久久 | 人妻激情综合久久久久蜜桃 | 国产精品一国产AV麻豆 | 99精品国产在热 | 天堂视频在线观看免费完整版 | 在线日本高清日本免费 | 港台三级大全 | 99精品免费久久久久久久久蜜桃 | 亚洲精品久久久无码一区二区 | 婷婷久久综合九色综合伊人色 | 国产精品亚洲AV毛片一区二区三区 | 一二三四免费中文在线1 | 亚洲AV无码专区国产精品麻豆 | 国产成人一区二区三中文 | 日产国产欧美韩国在线 | 欧美另类jizzhd| 小短文H啪纯肉公交车 | 亚洲人成影院在线播放 | 黄页网址大全免费观看 | 91avcom| 花蝴蝶免费版高清版 |