久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

      <style id="76ofp"></style>
      <rt id="76ofp"></rt>
      <form id="76ofp"><optgroup id="76ofp"></optgroup></form>
      1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

        手機站
        千鋒教育

        千鋒學習站 | 隨時隨地免費學

        千鋒教育

        掃一掃進入千鋒手機站

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

        關(guān)注千鋒學習站小程序
        隨時隨地免費學習課程

        當前位置:首頁  >  技術(shù)干貨  > Python標準庫之collections模塊

        Python標準庫之collections模塊

        來源:千鋒教育
        發(fā)布人:xqq
        時間: 2023-11-07 06:07:32 1699308452

        collections模塊簡介

        collections是Python標準庫里有關(guān)數(shù)據(jù)類型的模塊,里面包含了一些實用的數(shù)據(jù)類型,在某些情況下作為Python標準內(nèi)建容器(dict,list,set,和tuple)的替代選擇。

        namedtuple()命名元組的工廠函數(shù)

        Python官方文檔上是這樣說的:"命名元組賦予每個位置一個含義,提供可讀性和自文檔性。它們可以用于任何普通元組,并添加了通過名字獲取值的能力,通過索引值也是可以的?!拔沂沁@樣理解的:它可以構(gòu)建一個有名字的類,而且為元組中的元素添加了更易懂的"名字”(或者說是對元素的簡單描述),這樣就可以用"名字"取值。

        如果元組內(nèi)的元素很多,比如記錄一個人的身高,年齡,家庭住址,電話號碼…等等,只靠索引訪問這些信息是很麻煩的,這就凸顯出了"名字"的重要性。

        fromcollectionsimportnamedtuple

        City=namedtuple('City','namecountry')#注1

        beijing=City('Beijing','China')

        print(beijing)#City(name='Beijing',country='China')

        print(beijing.name)#通過"名字"獲取對應(yīng)的值

        print(beijing.country)

        print(beijing[0])#同樣支持用索引訪問

        注1.創(chuàng)建了一個類名是"City"的類,其中"name"和"country"是"名字","名字"可以是數(shù)個字符串組成的可迭代類型(比如list),還可以是用空格分開的字符串。

        下面介紹一些常用的功能:

        fromcollectionsimportnamedtuple

        Point=namedtuple('Point',['x','y'])

        print(Point._fields)#_fields方法會返回一個包含"Point"類里所有"名字"的元組('x','y')

        p=[1,2]

        print(Point._make(p))#_make()接受一個可迭代對象創(chuàng)建新的命名元組

        p=Point(1,2)

        print(p._asdict())#返回一個OrderedDict(這個數(shù)據(jù)類型以后再談),它能友好地呈現(xiàn)出元組里的信息

        print(p._replace(x=2))#返回一個新的命名元組實例,并將指定"名字"的值替換為新的值

        print(p)#_replace()返回的是新的命名元組實例,所以p不會改變

        p2={'x':2,'y':3}

        print(Point(**p2))#將字典轉(zhuǎn)化為命名元組

        Counter(計數(shù)器)

        Counter是dict的子類,可以給可散列對象(文末有解釋)計數(shù)。

        廢話不多說,直接上例子:

        fromcollectionsimportCounter

        a=Counter('aaabbcdddd')#統(tǒng)計'aaabbcdddd'(可迭代對象)里字母出現(xiàn)的次數(shù)并創(chuàng)建對應(yīng)的計數(shù)器(按次數(shù)大小排列)

        print(a)

        b=Counter()#空的計數(shù)器

        print(b)

        c=Counter({'a':3,'b':2,'c':3,'d':4})#根據(jù)字典創(chuàng)建計數(shù)器

        print(c)

        d=Counter(a=3,b=2,c=1,d=4)#根據(jù)鍵值創(chuàng)建

        print(d)

        e=Counter(['a','a','b'])#也可以換成其他可迭代對象

        print(e['a'])#統(tǒng)計列表中'a'出現(xiàn)的次數(shù)

        print(e['c'])#如果沒有相應(yīng)的鍵就返回零

        下面介紹一些常用的功能:

        fromcollectionsimportCounter

        #elements()方法會返回一個迭代器

        a=Counter(a=2,b=1,c=0,d=-1)#elements()函數(shù)會忽略計數(shù)值小于1的元素

        print(sorted(f.elements()))#迭代器不能直接打印,需要先用sorted()函數(shù)新建一個列表

        #most_common([n])返回一個包含n個最常見的元素及出現(xiàn)次數(shù)的列表

        b=Counter('aaabbcdddd')

        print(g.most_common(2))#結(jié)果:[('d',4),('a',3)]

        print(g.most_common())#如果不傳參或傳"None",將返回計數(shù)器中的所有元素

        print(g.most_common(None))

        #subtract減去元素

        e=Counter(a=4,b=1,c=0,d=-1)

        f=Counter(a=2,b=1,c=2,d=0)

        e.subtract(f)#這里既可以減去可迭代對象(如字符串,列表)也可以是映射對象(如字典)

        print(e)

        e.subtract('aaa')

        print(e)#輸入和輸出都可以是0或者負數(shù)

        關(guān)于可散列對象的介紹不多,《流暢的Python》里是這樣說的(選自Python詞匯表):

        如果一個對象是可散列的,那么在這個對象的生命周期中,他的散列值是不會變的,而且這個對象需要實現(xiàn)__hash__()方法。另外還要有__eq__()方法,這樣才能和其他鍵作比較。如果兩個可散列對象是相等的,那么他們的散列值一定是一樣的。

        簡單說可散列對象就是能被映射成數(shù)字的對象。

        “可散列”,"映射"會牽扯到一種數(shù)據(jù)結(jié)構(gòu):散列表(《算法圖解》第五章和《流暢的Python》第三章中對散列表都有一定介紹,讀者可以用微信讀書了解這種數(shù)據(jù)結(jié)構(gòu))

        在理解了散列表之后,可散列對象就不難理解了。

        下面看幾個例子:

        a=1

        print(hash(a))

        s='a'

        print(hash(s))

        t1=(1,2,3)

        t2=(1,[2,3])

        t3=(1,frozenset([2,3]))

        print(hash(t1))

        print(hash(t2))

        print(hash(t3))

        l=[1,2]

        print(hash(l))#list是不可散列的,所以會拋出異常:TypeError:unhashabletype:'list'

        b=1

        print(hash(a)==hash(b))

        在以上的例子中,變量a,s,t1和t3都是可散列對象(都實現(xiàn)了__hash__()方法);

        最后一個例子證明了"如果兩個可散列對象是相等的,那么他們的散列值一定是一樣的"這句話。

        總結(jié)一下可散列對象:

        1.str(s),bytes,和數(shù)值類型(a);

        2.frozenset,因為frozenset只能容納可散列類型;

        3.在元組里的所有元素都是可散列類型的情況下,它才是可散列的。

        以上內(nèi)容為大家介紹了Python標準庫之collections模塊,希望對大家有所幫助,如果想要了解更多Python相關(guān)知識,請關(guān)注IT培訓(xùn)機構(gòu):千鋒教育。http://m.2667701.com/

        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
        請您保持通訊暢通,專屬學習老師24小時內(nèi)將與您1V1溝通
        免費領(lǐng)取
        今日已有369人領(lǐng)取成功
        劉同學 138****2860 剛剛成功領(lǐng)取
        王同學 131****2015 剛剛成功領(lǐng)取
        張同學 133****4652 剛剛成功領(lǐng)取
        李同學 135****8607 剛剛成功領(lǐng)取
        楊同學 132****5667 剛剛成功領(lǐng)取
        岳同學 134****6652 剛剛成功領(lǐng)取
        梁同學 157****2950 剛剛成功領(lǐng)取
        劉同學 189****1015 剛剛成功領(lǐng)取
        張同學 155****4678 剛剛成功領(lǐng)取
        鄒同學 139****2907 剛剛成功領(lǐng)取
        董同學 138****2867 剛剛成功領(lǐng)取
        周同學 136****3602 剛剛成功領(lǐng)取
        相關(guān)推薦HOT
        涟水县| 金秀| 卢龙县| 本溪市| 曲周县| 广河县| 额尔古纳市| 白玉县| 岱山县| 永福县| 屏山县| 西安市| 同德县| 彭州市| 上饶市| 西华县| 克什克腾旗| 浮山县| 荆门市| 灵丘县| 策勒县| 岳池县| 绥滨县| 张家界市| 台南市| 西畴县| 卢氏县| 日土县| 景泰县| 久治县| 新巴尔虎左旗| 贵州省| 饶河县| 广宁县| 乌什县| 抚顺县| 正镶白旗| 临潭县| 喜德县| 绥棱县| 秦皇岛市|