欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一文帶你深入探究Python?Collections模塊

 更新時(shí)間:2023年11月10日 10:38:43   作者:郝同學(xué)的測開筆記  
Python中Collections模塊實(shí)現(xiàn)了一些專門化的容器,提供了對?Python?的通用內(nèi)建容器?dict、list、set?和?tuple?的補(bǔ)充,下面我們就來了解一下它的具體用法吧

前言

這幾天刷leetcode題時(shí),看到題解中有這樣一行代碼collections.defaultdict(list),不明白是啥意思,平時(shí)開發(fā)的腳本中未遇到,借著這個(gè)機(jī)會(huì),學(xué)習(xí)一下collections模塊的用法。

collections

這個(gè)模塊實(shí)現(xiàn)了一些專門化的容器,提供了對 Python 的通用內(nèi)建容器 dict、list、settuple 的補(bǔ)充。

defaultdict

defaultdictdict(字典)的一個(gè)子類,它為字典操作中的缺失鍵提供了默認(rèn)值。這在處理計(jì)數(shù)、分組等操作時(shí)非常有用。

案例:給定一個(gè)列表,將每個(gè)單詞按首字母分組

import collections
?
mp = collections.defaultdict(list)
?
words = ['apple', 'banana', 'orange', 'pear', 'peach']
for word in words:
    mp[word[0]].append(word)
?
print(mp) # defaultdict(<class 'list'>, {'a': ['apple'], 'b': ['banana'], 'o': ['orange'], 'p': ['pear', 'peach']})

mp = collections.defaultdict(list)這行代碼創(chuàng)建了一個(gè)defaultdict對象,其中list是指定的默認(rèn)值類型。

這意味著當(dāng)我們通過mp訪問一個(gè)不存在的鍵時(shí),defaultdict會(huì)自動(dòng)創(chuàng)建這個(gè)鍵,并將其對應(yīng)的值初始化為一個(gè)空列表。比如上面這段代碼,我們在print(mp)前面增加mp['aa'],此時(shí)會(huì)輸出defaultdict(<class 'list'>, {'a': ['apple'], 'b': ['banana'], 'o': ['orange'], 'p': ['pear', 'peach'], 'aa': []})

Counter

Counter是一個(gè)簡單而強(qiáng)大的計(jì)數(shù)器工具,用于統(tǒng)計(jì)可迭代對象中各元素出現(xiàn)的次數(shù)。

案例:統(tǒng)計(jì)一個(gè)字符串中字符出現(xiàn)的次數(shù)

import collections
?
s = "abracadabra"
counter = collections.Counter(s)
print(counter) # 輸出結(jié)果:Counter({'a': 5, 'b': 2, 'r': 2, 'c': 1, 'd': 1})

namedtuple

namedtuple創(chuàng)建了一個(gè)帶字段名的元組類型,它可以對元組進(jìn)行命名,使得代碼更易讀。

案例:創(chuàng)建一個(gè)表示坐標(biāo)的數(shù)據(jù)結(jié)構(gòu)

import collections
?
Point = collections.namedtuple('Point', ['x', 'y'])
p = Point(11, y=22)
print(p.x, p.y) # 輸出結(jié)果:11 22

deque

deque是一個(gè)雙向隊(duì)列,可以在兩端快速插入和刪除元素,適用于需要高效地進(jìn)行隊(duì)列和棧操作的場景。

案例:使用deque實(shí)現(xiàn)一個(gè)簡單的循環(huán)隊(duì)列

import collections
?
q = collections.deque(maxlen=3)
q.append(1)
q.append(2)
q.append(3)
print(q)  # 輸出結(jié)果:deque([1, 2, 3], maxlen=3)
q.append(4)
print(q)  # 輸出結(jié)果:deque([2, 3, 4], maxlen=3)

OrderedDict

有序字典,保持元素被插入的順序。

案例:實(shí)現(xiàn)LRU緩存:LRU(Least Recently Used)緩存是一種常見的緩存策略,當(dāng)緩存滿時(shí),會(huì)淘汰最近最少使用的元素。OrderedDict可以很方便地實(shí)現(xiàn)LRU緩存,每次訪問一個(gè)元素時(shí),將其移到字典的末尾,這樣最近訪問的元素就會(huì)被保留,最早訪問的元素就會(huì)被淘汰。

from collections import OrderedDict
?
class LRUCache:
    def __init__(self, capacity):
        self.capacity = capacity
        self.cache = OrderedDict()
?
    def get(self, key):
        if key in self.cache:
            value = self.cache[key]
            # 將訪問的元素移到字典的末尾
            self.cache.move_to_end(key)
            return value
        else:
            return -1
?
    def put(self, key, value):
        if key in self.cache:
            # 如果key已經(jīng)存在,將其移到字典的末尾
            self.cache.move_to_end(key)
        self.cache[key] = value
        if len(self.cache) > self.capacity:
            # 如果緩存已滿,淘汰最早訪問的元素
            self.cache.popitem(last=False)

ChainMap

在多個(gè)字典中查找某個(gè)鍵的值,可以使用ChainMap將這些字典組合成一個(gè)邏輯上的字典,從而方便地進(jìn)行查找操作。

案例:使用ChainMap查找鍵的值:

from collections import ChainMap
?
dict1 = {'a': 1, 'b': 2}
dict2 = {'c': 3, 'd': 4}
dict3 = {'e': 5, 'f': 6}
?
chain_map = ChainMap(dict1, dict2, dict3)
?
value = chain_map['a']
print(value)  # 輸出: 1
?
value = chain_map['c']
print(value)  # 輸出: 3

UserDict

當(dāng)需要?jiǎng)?chuàng)建一個(gè)自定義的字典類時(shí),可以繼承UserDict類,從而方便地實(shí)現(xiàn)自定義的字典功能。

案例:使用UserDict創(chuàng)建自定義字典類

from collections import UserDict
?
class MyDict(UserDict):
    def __setitem__(self, key, value):
        super().__setitem__(key, value * 2)
?
my_dict = MyDict()
my_dict['a'] = 1
my_dict['b'] = 2
?
print(my_dict)  # 輸出: {'a': 2, 'b': 4}

UserList

當(dāng)需要?jiǎng)?chuàng)建一個(gè)自定義的列表類時(shí),可以繼承UserList類,從而方便地實(shí)現(xiàn)自定義的列表功能。

案例:使用UserList創(chuàng)建自定義列表類

from collections import UserList
?
class MyList(UserList):
    def remove_duplicates(self):
        self.data = list(set(self.data))
?
my_list = MyList([1, 2, 2, 3, 4, 4, 5])
my_list.remove_duplicates()
?
print(my_list)  # 輸出: [1, 2, 3, 4, 5]

UserString

當(dāng)需要?jiǎng)?chuàng)建一個(gè)自定義的字符串類時(shí),可以繼承UserString類,從而方便地實(shí)現(xiàn)自定義的字符串功能。

案例:使用UserString創(chuàng)建自定義字符串類

from collections import UserString
?
class MyString(UserString):
    def remove_whitespace(self):
        self.data = self.data.replace(' ', '')
?
my_string = MyString('Hello World')
my_string.remove_whitespace()
?
print(my_string)  # 輸出: HelloWorld

最后

這篇文章主要介紹了collections模塊中幾個(gè)常用數(shù)據(jù)結(jié)構(gòu)的簡單介紹和示例。使用這些數(shù)據(jù)結(jié)構(gòu)能夠讓我們更加高效地處理各種實(shí)際問題,提高代碼的可讀性和可維護(hù)性。

以上就是一文帶你深入探究Python Collections模塊的詳細(xì)內(nèi)容,更多關(guān)于Python Collections的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 使用 Python 合并多個(gè)格式一致的 Excel 文件(推薦)

    使用 Python 合并多個(gè)格式一致的 Excel 文件(推薦)

    這篇文章主要介紹了使用 Python 合并多個(gè)格式一致的 Excel 文件,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-12-12
  • 一款Python工具制作的動(dòng)態(tài)條形圖(強(qiáng)烈推薦!)

    一款Python工具制作的動(dòng)態(tài)條形圖(強(qiáng)烈推薦!)

    有時(shí)為了方便看數(shù)據(jù)的變化情況,需要畫一個(gè)動(dòng)態(tài)圖來看整體的變化情況,下面這篇文章主要給大家介紹了一款Python工具制作的動(dòng)態(tài)條形圖的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • python抓取skywalking中超過2s的告警接口

    python抓取skywalking中超過2s的告警接口

    這篇文章主要為大家介紹了python抓取skywalking中超過2s的告警接口詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • Python實(shí)現(xiàn)執(zhí)行Shell命令并獲取輸出

    Python實(shí)現(xiàn)執(zhí)行Shell命令并獲取輸出

    這篇文章主要介紹了如何借助?os.system()?從?Python?腳本執(zhí)行?cmd?命令,以及如何借助?Python?中的?subprocess?模塊以更簡單的方式從腳本執(zhí)行?cmd?命令,感興趣的小伙伴可以了解下
    2023-10-10
  • 詳解Python中位運(yùn)算的簡單實(shí)現(xiàn)

    詳解Python中位運(yùn)算的簡單實(shí)現(xiàn)

    位運(yùn)算就是直接對整數(shù)在內(nèi)存中對應(yīng)的二進(jìn)制位進(jìn)行操作,一般是將數(shù)字化為二進(jìn)制數(shù)后進(jìn)行操作。本文將利用Python語言實(shí)現(xiàn)位運(yùn)算,感興趣的可以了解一下
    2022-06-06
  • 用Python解析XML的幾種常見方法的介紹

    用Python解析XML的幾種常見方法的介紹

    這篇文章主要介紹了用Python解析XML的幾種常見方法,包括快速的使用ElementTree模塊等方法的實(shí)例介紹,需要的朋友可以參考下
    2015-04-04
  • python實(shí)現(xiàn)DEM數(shù)據(jù)的陰影生成的方法

    python實(shí)現(xiàn)DEM數(shù)據(jù)的陰影生成的方法

    這篇文章主要介紹了python實(shí)現(xiàn)DEM數(shù)據(jù)的陰影生成的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • Python實(shí)現(xiàn)字典的遍歷與排序功能示例

    Python實(shí)現(xiàn)字典的遍歷與排序功能示例

    這篇文章主要介紹了Python實(shí)現(xiàn)字典的遍歷與排序功能,結(jié)合實(shí)例形式分析了Python字典的遍歷與排序相關(guān)函數(shù)與使用技巧,需要的朋友可以參考下
    2017-12-12
  • 使用python把xmind轉(zhuǎn)換成excel測試用例的實(shí)現(xiàn)代碼

    使用python把xmind轉(zhuǎn)換成excel測試用例的實(shí)現(xiàn)代碼

    這篇文章主要介紹了使用python把xmind轉(zhuǎn)換成excel測試用例的實(shí)現(xiàn)代碼,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-10-10
  • Python實(shí)現(xiàn)繪制置信區(qū)間

    Python實(shí)現(xiàn)繪制置信區(qū)間

    置信區(qū)間是從觀測數(shù)據(jù)的統(tǒng)計(jì)量計(jì)算的一種估計(jì)值,它給出了一個(gè)可能包含具有特定置信水平的總體參數(shù)的值范圍,下面我們就來看看如何使用Python繪制置信區(qū)間吧
    2024-02-02

最新評(píng)論