首頁 > 後端開發 > Python教學 > python中collection模組的簡單介紹(附範例)

python中collection模組的簡單介紹(附範例)

不言
發布: 2018-09-25 16:52:51
原創
3141 人瀏覽過

這篇文章帶給大家的內容是關於python中collection模組的簡單介紹(附範例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

collection模組:

在內建資料型別(dict、list、set、tuple)的基礎上,collections模組也提供了幾個額外的資料型別:Counter、deque、defaultdict、 namedtuple和OrderedDict等。

1:namedtuple

產生可以使用名字來存取元素內容的元組(tuple)
例如:表示一個座標

from collections import namedtuple
point = namedtuple('point',['x','y'])
p=point(1,2)
print(p.x)
print(p.y)
登入後複製
>>1
>>2
登入後複製

2:deque雙端佇列:

雙端佇列,可以快速的從另外一側追加和推出物件。
使用list儲存資料時,按索引存取元素很快,但是插入和刪除元素就很慢了,因為list是線性存儲,資料量大的時候,插入和刪除效率很低

# deque是為了高效實現插入和刪除操作的雙向列表,適合用於隊列和堆疊

from collections import deque
q=deque(['a','b','c'])
q.append('x')
q.appendleft('y')
print(q)
登入後複製
>>deque(['y', 'a', 'b', 'c', 'x'])
登入後複製

3:Counter計數器

計數器,主要用來計數
目的是用來追蹤值出項的次數,它是一個無序的容器類型,以字典的鍵值對的形式存儲,其中元素作為key,其計數作為value
計數值可以是任意的interger(包括0和負數) ,

建立:

from collections import Counter
#创建一个空的类
c=Counter()
#从一个可迭代对象中创建
c=Counter('gallahad')
#从一个字典对象创建
c=Counter({'a':2,'b':4})
#从一组键值对创建
c=Counter(a=2,b=4)
登入後複製

計數值的存取與缺少的鍵
當所存取的鍵不存在時,返回0,而不是KeyError;否則傳回它的計數

計數值的存取

c=Counter('gallahad')
print(c['a'])
print(c['z'])
>>3
>>0
登入後複製

計數器的更新(update和subtract)
可以使用一個可迭代物件或另一個Counter物件來更新鍵值對

update增加

c=Counter('gallahad')
c.update('chengzheng')
print(c['e'])
>>2
d=Counter('holloword')
c.update(d)
print(c['l'])
>>4
登入後複製

subtract減少

c=Counter('gallahad')
c.subtract('g')
print(c['g'])
>>0
d=Counter('all')
c.subtract(d)
print(c['l'])
>>0
登入後複製

鍵的修改和刪除
當計數值為0時,並不表示元素被刪除,刪除元素應使用del

c=Counter('gallahad')
print(c)
c['a']=0
print(c)
del c['l']
print(c)
>>Counter({'a': 3, 'l': 2, 'g': 1, 'h': 1, 'd': 1})
>>Counter({'l': 2, 'g': 1, 'h': 1, 'd': 1, 'a': 0})
>>Counter({'g': 1, 'h': 1, 'd': 1, 'a': 0})
登入後複製

elements():
傳回迭代器。元素被重複了多少次,在這個迭代器中就包含多少個該元素。元素排列無確定順序,個數小於1的元素不包含。

c =Counter(a=4,b=2,c=0,d=-2)
a =list(c.elements())
print(a)
>>['a', 'a', 'a', 'a', 'b', 'b']
登入後複製

most_common():
傳回一個top (n)清單。如果n沒有被指定,則傳回所有元素,當多個元素計數值相同時,排列是無序的

c =Counter('xsgffikgkhgdyrduykkf')
a =c.most_common(3)
print(a)
登入後複製

其他操作:

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个元素
c += Counter()  # 移除0和负值
登入後複製

4:OrderdDict有序字典

使用字典(dict),key是無序的,在對字典做迭代時,我們無法確定key的順序。
如果要key有順序,可以用OrderdDict

from collections import OrderedDict

d=dict([('a',1),('b',2),('c',3)])
print(d)
od=OrderedDict([('a',1),('b',2),('c',3)])
print(od)
>>{'c': 3, 'b': 2, 'a': 1}
>>OrderedDict([('a', 1), ('b', 2), ('c', 3)])
登入後複製


注意:OrderdDict是按照插入的順序來排序的,不是按照key本身來排序​​的。

od=OrderedDict([('a',1),('c',3),('b',2)])
print(od)
>>OrderedDict([('a', 1), ('c', 3), ('b', 2)])
登入後複製

5:defaultdict:有預設值的字典

範例:
有下列值集合[11,22,33,44,55,66,77, 88,99,90...],將所有大於66 的值儲存到字典的第一個key中,將小於66 的值儲存至第二個key的值中。

即: {'k1': 大於66 , 'k2': 小於66}

from collections import defaultdict

values = [11, 22, 33,44,55,66,77,88,99,90]
my_dict = defaultdict(list)
for value in  values:
    if value>66:
        my_dict['k1'].append(value)
    else:
        my_dict['k2'].append(value)
print(my_dict)
登入後複製
>>defaultdict(<class &#39;list&#39;>, {&#39;k2&#39;: [11, 22, 33, 44, 55, 66], &#39;k1&#39;: [77, 88, 99, 90]})
登入後複製

以上是python中collection模組的簡單介紹(附範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板