python--模塊之collection

来源:https://www.cnblogs.com/chen-1054425078/archive/2018/09/23/9691708.html
-Advertisement-
Play Games

collection模塊: 在內置數據類型(dict、list、set、tuple)的基礎上,collections模塊還提供了幾個額外的數據類型:Counter、deque、defaultdict、namedtuple和OrderedDict等。 1:namedtuple 生成可以使用名字來訪問元 ...


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 'list'>, {'k2': [11, 22, 33, 44, 55, 66], 'k1': [77, 88, 99, 90]})


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 問題描述: 在 iOS 系統中,用微信打開了 A 頁面的鏈接,然後由 A 頁面進入 B 頁面 在 B 頁面打開微信右上角菜單,使用“複製鏈接”功能 最後粘貼出來的鏈接是 A 頁面的鏈接 分析原因: 這個問題在微信 6.2 時代就已存在,GitHub 上有很多人到 weui 的主頁提 issue ht ...
  • 本博文配合 阮一峰 《ES6 標準入門(第3版)》一書進行簡要概述 ES6 中變數的解構賦值。 數組的解構賦值 基本用法 ES6 允許按照一定模式,從數組和對象中提取值,對變數進行賦值,這被稱為解構。 ES6 以前,為變數賦值,只能直接指定值。 ES6 允許寫成下麵的樣式。 該代碼表示,可以從數組中 ...
  • 這是在網上看到的一道面試題 嗯 考察的知識點挺多 其他的就不多說了 我用我的理解與解題方式來解答這道題 1.首先是變數提升 變數提升包括var 聲明的變數和fucntion 聲明 舉個例子 1.var a=4; 2.function test(){ console.log(456); }; 函數變數 ...
  • css清除瀏覽器預設樣式(代替 *{}) 將代碼放入 css 文件,使用 link 引入。 ...
  • String能變化嗎?和StringBuffer的區別是什麼? ...
  • java中單態模式或單例模式(Singleton)有什麼意義? ...
  • 5.object和Class的深入理解 屬性和方法 (視頻下載) (全部書籍) 抽象Abstract:【新手可忽略不影響繼續學習】 (視頻下載) (全部書籍)很多java 的書中都談到了抽象abstract的概念,到底什麼是抽象?馬克-to-win:抽取關鍵相關特性(屬性和方法)構成對象,用程式的方 ...
  • 最近的一個小項目是做一個簡單的數據倉庫,需要將其他資料庫的數據抽取出來,並通過而出抽取成頁面需要的數據,以空間換時間的方式,讓後端報表查詢更快。 因為在抽取的過程中,有一定的先後順序,需要做一個任務調度器,某一優先順序的會先執行,然後會進入下一個優先順序的隊列任務中。 先定義了一個Map的集合,key是 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...