摘要:?jiǎn)栴}怎樣找出一個(gè)序列中出現(xiàn)次數(shù)最多的元素解決方案使用庫中的對(duì)象可以方便的求出現(xiàn)次數(shù)最多的前個(gè)元素直接使用成員函數(shù)就好了,例如輸出討論對(duì)象是的子類,事實(shí)上內(nèi)部存儲(chǔ)也是按照字典存儲(chǔ)的,這里的就是次數(shù),所以對(duì)象支持對(duì)象的所有操作每一個(gè)對(duì)象初始化
問題
怎樣找出一個(gè)序列中出現(xiàn)次數(shù)最多的元素?
解決方案使用collections庫中的Counter對(duì)象可以方便的求出現(xiàn)次數(shù)最多的前N個(gè)元素
直接使用most_common成員函數(shù)就好了,例如:
from collections import Counter words = [ "look", "into", "my", "eyes", "look", "into", "my", "eyes", "the", "eyes", "the", "eyes", "the", "eyes", "not", "around", "the", "eyes", "don"t", "look", "around", "the", "eyes", "look", "into", "my", "eyes", "you"re", "under" ] counter = Counter(words) print(counter.most_common(1))
輸出
[("eyes", 8)]討論
Counter對(duì)象是dict的子類,事實(shí)上內(nèi)部存儲(chǔ)也是按照k-v字典存儲(chǔ)的,這里的v就是次數(shù),所以Counter對(duì)象支持dict對(duì)象的所有操作
每一個(gè)Counter對(duì)象初始化可以接受可迭代對(duì)象(iterable)、字典、關(guān)鍵字參數(shù)
>>> c = Counter() # a new, empty counter >>> c = Counter("gallahad") # a new counter from an iterable >>> c = Counter({"red": 4, "blue": 2}) # a new counter from a mapping >>> c = Counter(cats=4, dogs=8) # a new counter from keyword args
此外,Counter對(duì)象還支持?jǐn)?shù)學(xué)操作
>>> c = Counter(a=3, b=1) >>> d = Counter(a=1, b=2) >>> c + d # add two counters together: c[x] + d[x] Counter({"a": 4, "b": 3}) >>> c - d # subtract (keeping only positive counts) Counter({"a": 2}) >>> c & d # intersection: min(c[x], d[x]) Counter({"a": 1, "b": 1}) >>> c | d # union: max(c[x], d[x]) Counter({"a": 3, "b": 2})
所以在遇到跟計(jì)數(shù)有關(guān)的問題時(shí),不妨首先考慮一下Counter對(duì)象
來源Python Cookbook
關(guān)注歡迎關(guān)注我的微信公眾號(hào):python每日一練
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/44683.html
摘要:?jiǎn)栴}在每日一練中介紹了如何一個(gè)可迭代對(duì)象,使用運(yùn)算符即可但往往我們遇到的問題是可迭代對(duì)象中的數(shù)量是不確定的這個(gè)時(shí)候該如何拿到我們想要的元素,比如我們只需要可迭代對(duì)象的第一個(gè)或者最后一個(gè)元素而已解決方案使用中的運(yùn)算符例如我們需要拿到一個(gè)元組的 問題 在每日一練0001中介紹了如何unpack一個(gè)可迭代對(duì)象,使用,運(yùn)算符即可 但往往我們遇到的問題是可迭代對(duì)象中的數(shù)量是不確定的 這個(gè)時(shí)候該如...
摘要:?jiǎn)栴}如何序列化輸出元素包含字符串元組的字符串元組好繞舉個(gè)例子將輸出為解決方案容易想到使用函數(shù),但函數(shù)要求元素必須都是字符串類型,否則會(huì)拋出錯(cuò)誤一個(gè)比較簡(jiǎn)單的方法是將給進(jìn)中,然后再將給進(jìn)函數(shù),最后指定函數(shù)的參數(shù)來輸出如果想要將結(jié)果存儲(chǔ)起來,那 問題 如何序列化輸出元素包含字符串元組的字符串元組(好繞) 舉個(gè)例子 >>> zoo1 = (monkey, elephant) >>> zoo2...
摘要:?jiǎn)栴}如何執(zhí)行外部命令,如解決方案使用庫在之前,使用函數(shù)在及之后,使用函數(shù)討論命令的執(zhí)行默認(rèn)不需要環(huán)境,所以當(dāng)你使用作為參數(shù)時(shí),需要將置位,否則會(huì)報(bào)錯(cuò)誤通常來說對(duì)于執(zhí)行系統(tǒng)命令,我們會(huì)想到,但在官方文檔中已經(jīng)建議了使 問題 如何執(zhí)行外部命令,如ls -l 解決方案 使用subprocess庫 在Python 3.5之前,使用subprocess.call()函數(shù) >>> import s...
摘要:?jiǎn)栴}如何判斷一個(gè)文件是否存在解決方案這個(gè)問題可以分成幾類問題如果這里的文件指的是文件或目錄,我們可以用方法如果這里的文件指的是普通的文件,我們可以用方法如果這里的文件指的是目錄,我們可以用方法并且在之后,可以使用面向?qū)ο蟮姆椒ㄊ褂脦靵砼袛啵? 問題 如何判斷一個(gè)文件是否存在 解決方案 這個(gè)問題可以分成幾類問題 如果這里的文件指的是文件或目錄,我們可以用os.path.exists()方法...
摘要:?jiǎn)栴}你需要執(zhí)行簡(jiǎn)單的日期操作,計(jì)算兩個(gè)日期間隔多少天某個(gè)日期后的多少天是幾月幾日轉(zhuǎn)換時(shí)間字符串的格式等解決方案使用庫中的和類其中類代表一個(gè)日期時(shí)間,例如年月日點(diǎn)分秒類代表一個(gè)日期間隔對(duì)于實(shí)例,可以直接進(jìn)行數(shù)學(xué)運(yùn)算得到一個(gè)實(shí)例,也就是兩個(gè)日 問題 你需要執(zhí)行簡(jiǎn)單的日期操作,計(jì)算兩個(gè)日期間隔多少天、某個(gè)日期后的多少天是幾月幾日、轉(zhuǎn)換時(shí)間字符串的格式等 解決方案 使用datetime庫中的d...
閱讀 2633·2021-11-17 17:00
閱讀 1891·2021-10-11 10:57
閱讀 3761·2021-09-09 11:33
閱讀 928·2021-09-09 09:33
閱讀 3562·2019-08-30 14:20
閱讀 3329·2019-08-29 11:25
閱讀 2810·2019-08-26 13:48
閱讀 750·2019-08-26 11:52