91aaa在线国内观看,亚洲AV午夜福利精品一区二区,久久偷拍人视频,久久播这里有免费视播

<strong id="fvuar"></strong>

  • <sub id="fvuar"><dl id="fvuar"><em id="fvuar"></em></dl></sub>

    1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

      手機(jī)站
      千鋒教育

      千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

      千鋒教育

      掃一掃進(jìn)入千鋒手機(jī)站

      領(lǐng)取全套視頻
      千鋒教育

      關(guān)注千鋒學(xué)習(xí)站小程序
      隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

      當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > python生成器表達(dá)式

      python生成器表達(dá)式

      來(lái)源:千鋒教育
      發(fā)布人:xqq
      時(shí)間: 2023-11-07 20:27:59 1699360079

      生成器表達(dá)式來(lái)源于迭代和列表解析的組合,生成器和列表解析類似,但是它使用尖括號(hào)而不是方括號(hào)

      >>>#列表解析生成列表

      >>>[x**3forxinrange(5)]

      [0,1,8,27,64]

      >>>

      >>>#生成器表達(dá)式

      >>>(x**3forxinrange(5))

      at0x000000000315F678>

      >>>#兩者之間轉(zhuǎn)換

      >>>list(x**3forxinrange(5))

      [0,1,8,27,64]

      一個(gè)迭代既可以被寫成生成器函數(shù),也可以被協(xié)程生成器表達(dá)式,均支持自動(dòng)和手動(dòng)迭代。而且這些生成器只支持一個(gè)active迭代,也就是說(shuō)生成器的迭代器就是生成器本身。

      迭代器(迭代就是循環(huán))

      迭代器包含有next方法的實(shí)現(xiàn),在正確的范圍內(nèi)返回期待的數(shù)據(jù)以及超出范圍后能夠拋出StopIteration的錯(cuò)誤停止迭代。

      我們已經(jīng)知道,可以直接作用于for循環(huán)的數(shù)據(jù)類型有以下幾種:

      一類是集合數(shù)據(jù)類型,如list,tuple,dict,set,str等

      一類是generator,包括生成器和帶yield的generatorfunction

      這些可以直接作用于for循環(huán)的對(duì)象統(tǒng)稱為可迭代對(duì)象:Iterable

      可以使用isinstance()判斷一個(gè)對(duì)象是否為可Iterable對(duì)象

      >>>fromcollectionsimportIterable

      >>>isinstance([],Iterable)

      True

      >>>isinstance({},Iterable)

      True

      >>>isinstance('abc',Iterable)

      True

      >>>isinstance((xforxinrange(10)),Iterable)

      True

      >>>isinstance(100,Iterable)

      False

      而生成器不但可以作用于for循環(huán),還可以被next()函數(shù)不斷調(diào)用并返回下一個(gè)值,直到最后拋出StopIteration錯(cuò)誤表示無(wú)法繼續(xù)返回下一個(gè)值了。

      所以這里講一下迭代器

      一個(gè)實(shí)現(xiàn)了iter方法的對(duì)象是可迭代的,一個(gè)實(shí)現(xiàn)next方法并且是可迭代的對(duì)象是迭代器。

      可以被next()函數(shù)調(diào)用并不斷返回下一個(gè)值的對(duì)象稱為迭代器:Iterator。

      所以一個(gè)實(shí)現(xiàn)了iter方法和next方法的對(duì)象就是迭代器。

      可以使用isinstance()判斷一個(gè)對(duì)象是否是Iterator對(duì)象:

      >>>fromcollectionsimportIterator

      >>>isinstance((xforxinrange(10)),Iterator)

      True

      >>>isinstance([],Iterator)

      False

      >>>isinstance({},Iterator)

      False

      >>>isinstance('abc',Iterator)

      False

      生成器都是Iterator對(duì)象,但list、dict、str雖然是Iterable(可迭代對(duì)象),卻不是Iterator(迭代器)。

      把list、dict、str等Iterable變成Iterator可以使用iter()函數(shù):

      >>>isinstance(iter([]),Iterator)

      True

      >>>isinstance(iter('abc'),Iterator)

      True

      你可能會(huì)問(wèn),為什么list、dict、str等數(shù)據(jù)類型不是Iterator?

      這是因?yàn)镻ython的Iterator對(duì)象表示的是一個(gè)數(shù)據(jù)流,Iterator對(duì)象可以被next()函數(shù)調(diào)用并不斷返回下一個(gè)數(shù)據(jù),直到?jīng)]有數(shù)據(jù)時(shí)拋出StopIteration錯(cuò)誤。可以把這個(gè)數(shù)據(jù)流看做是一個(gè)有序序列,但我們卻不能提前知道序列的長(zhǎng)度,只能不斷通過(guò)next()函數(shù)實(shí)現(xiàn)按需計(jì)算下一個(gè)數(shù)據(jù),所以Iterator的計(jì)算是惰性的,只有在需要返回下一個(gè)數(shù)據(jù)時(shí)它才會(huì)計(jì)算。

      Iterator甚至可以表示一個(gè)無(wú)限大的數(shù)據(jù)流,例如全體自然數(shù)。而使用list是永遠(yuǎn)不可能存儲(chǔ)全體自然數(shù)的。

      以上內(nèi)容為大家介紹了python生成器表達(dá)式,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。

      聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
      10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
      請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
      免費(fèi)領(lǐng)取
      今日已有369人領(lǐng)取成功
      劉同學(xué) 138****2860 剛剛成功領(lǐng)取
      王同學(xué) 131****2015 剛剛成功領(lǐng)取
      張同學(xué) 133****4652 剛剛成功領(lǐng)取
      李同學(xué) 135****8607 剛剛成功領(lǐng)取
      楊同學(xué) 132****5667 剛剛成功領(lǐng)取
      岳同學(xué) 134****6652 剛剛成功領(lǐng)取
      梁同學(xué) 157****2950 剛剛成功領(lǐng)取
      劉同學(xué) 189****1015 剛剛成功領(lǐng)取
      張同學(xué) 155****4678 剛剛成功領(lǐng)取
      鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
      董同學(xué) 138****2867 剛剛成功領(lǐng)取
      周同學(xué) 136****3602 剛剛成功領(lǐng)取
      相關(guān)推薦HOT
      Python 面向?qū)ο蟮能浖_發(fā)

      很多人在學(xué)完了python的class機(jī)制之后,遇到一個(gè)生產(chǎn)中的問(wèn)題,還是會(huì)懵逼,這其實(shí)太正常了,因?yàn)槿魏纬绦虻拈_發(fā)都是先設(shè)計(jì)后編程,python的cla...詳情>>

      2023-11-07 23:20:48
      Python 決策樹算法思想

      決策樹(decisiontree)是一個(gè)樹結(jié)構(gòu)(可以是二叉樹或者非二叉樹)。決策樹分為分類樹和回歸樹兩種,分類樹對(duì)離散變量做決策樹,回歸樹對(duì)連續(xù)變量做...詳情>>

      2023-11-07 23:10:00
      Python C4.5算法

      ID3算法的作者昆蘭基于上面的不足,對(duì)ID3算法做了改進(jìn),這就是C4.5算法,也許你會(huì)問(wèn),為什么不叫ID4,ID5之類的名字呢?那是因?yàn)闆Q策樹當(dāng)時(shí)太火...詳情>>

      2023-11-07 23:02:48
      Python 面向過(guò)程

      python面向過(guò)程優(yōu)點(diǎn):復(fù)雜的問(wèn)題流程化,進(jìn)而簡(jiǎn)單化(一個(gè)復(fù)雜的問(wèn)題,分成一個(gè)個(gè)小的步驟去實(shí)現(xiàn),實(shí)現(xiàn)小的步驟將會(huì)非常簡(jiǎn)單)舉個(gè)典型的面向過(guò)程...詳情>>

      2023-11-07 22:55:36
      Python編程規(guī)范的重要性

      首先談一下注釋:注釋不止是為了自己以后看的更清楚,還是為了以后的開發(fā)人員所準(zhǔn)備的,其實(shí)一段時(shí)間后,當(dāng)需要對(duì)程序做一些修改或者是改正某個(gè)...詳情>>

      2023-11-07 22:37:35