1. 程式人生 > >collections模塊—— Counter

collections模塊—— Counter

date 最小值 ger 刪除 error font CA copy 最大

collections模塊—— Counter


    Counter目的是用來跟蹤值出現的次數。它是一個無序的容器類型,以字典的形式存儲,其中元素作為key,其計數作為value。
    計數值可以是任意的lnterger(包括0和負數)。
    Counter類和其他的bags或multisets很相似。

   創建

      下面的代碼說明了Counter類創建的四種方法:

          Counter類的創建:
          from collections import Counter
        c = Counter()#創建一個空的Counter


        c = Counter(‘gallsdff‘)#從一個iterable對象(list、tuple、dict、字符串等)創建
        c = Counter({‘a‘:4,‘b‘:2}) #從一個字典對象創建
        c = Counter(a=4,b=2)#從一個鍵值對創建

    計數值的訪問與缺失的鍵

      當所訪問的鍵不存在時,返回0,而不是KeyError;否則返回他的計數。

          計數值的訪問:             

            from collections import Counter


            c = Counter("abcdefgab")
            c["a"]
            輸出:
            2
            c["h"]
            輸出:
            0

    計數器的更新(update和subtract)

      

      可以使用一個iterable對象或者另一個Counter對象來更新鍵值
      計數器的更新包括增加和減少兩種。其中,增加使用update()方法。
         計數器的更新(update)


            c = Counter(‘which‘)
            c.update(‘witch‘) # 使用另一個iterable對象更新
            c[‘h‘]
            輸出:
            3
            d = Counter(‘watch‘)
            c.update(d) # 使用另一個Counter對象更新
            c[‘h‘]
            輸出:
            4

    減少則使用subtract()方法:

      計數器的更新(subtract)

                    

            c = Counter(‘which‘)
            c.subtract(‘witch‘) # 使用另一個iterable對象更新
            c[‘h‘]
            輸出:1
            d = Counter(‘watch‘)
            c.subtract(d) # 使用另一個Counter對象更新
            c[‘a‘]
            輸出:-1

    鍵的修改和刪除

      當計數值為0時,並不意味著元素被刪除,刪除元素應當使用del。

       鍵的刪除:

              

            from collections import Counter
            c = Counter("sdfasdf")  
            print(c)
            輸出:
            Counter({‘s‘: 2, ‘d‘: 2, ‘f‘: 2, ‘a‘: 1})

            del c["d"]
            print(c)
            輸出:
            Counter({‘s‘: 2, ‘f‘: 2, ‘a‘: 1})

    clements()

      返回一個叠代器。元素被重復了多少次,在該叠代器中包含多少個該元素,元素排列無確定順序,個數小於1的元素不被包含。

      clements()方法

            

            from collections import Counter

            c = Counter(a=4,b=2,c=0,d=-2)
            print(list(c.elements()))
            輸出:
            [‘a‘, ‘a‘, ‘a‘, ‘a‘, ‘b‘, ‘b‘]

    most_common([n])

      返回一個TopN列表。如果n沒有被制定,則返回所有元素。當多個元素計數值相同時,排列是無確定順序的。

      most_common()方法

            

            from collections import Counter

            c = Counter("wrafsdfasdf")
            print(c.most_common())
            輸出:
            [(‘f‘, 3), (‘a‘, 2), (‘s‘, 2), (‘d‘, 2), (‘w‘, 1), (‘r‘, 1)]

            from collections import Counter

            c = Counter("wrafsdfasdf")
            print(c.most_common(3))
            輸出:
            [(‘f‘, 3), (‘a‘, 2), (‘s‘, 2)]

    淺拷貝cop

      淺拷貝copy 

            from collections import Counter

            c = Counter(‘asdcasdf‘)
            print(c)

            d = c.copy()
            print(d)
            輸出:
            Counter({‘a‘: 2, ‘s‘: 2, ‘d‘: 2, ‘c‘: 1, ‘f‘: 1})
            Counter({‘a‘: 2, ‘s‘: 2, ‘d‘: 2, ‘c‘: 1, ‘f‘: 1})

     

    算術和集合操作

      +、-、& | 操作也可以用於Counter。其中&和|操作分別返回兩個Counter對象各元素的最小值和最大值。需要註意的是,得到的Counter對象將刪除小於1的元素。

      Counter對象的算術和集合操作

            

            from collections import Counter

            c = Counter(a=3,b=1)
            d = Counter(a=1,b=2)
            print(c+d)
            輸出:
            Counter({‘a‘: 4, ‘b‘: 3})

    其他常用的操作

      下面是一些Counter類的常用操作,來源於Python官方文檔

   

            

            Counter類常用操作

            sum(c.values()) # 所有計數的總數
            c.clear() # 重置Counter對象,註意不是刪除
            list(c) # 將c中的鍵轉為列表
            set(c) # 將c中的鍵轉為set
            dict(c) # 將c中的鍵值對轉為字典
            c.items() # 轉為(elem, cnt)格式的列表
            Counter(dict(list_of_pairs)) # 從(elem, cnt)格式的列表轉換為Counter類對象
            c.most_common()[:-n:-1] # 取出計數最少的n個元素

collections模塊—— Counter