chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

python通過(guò)序列生成字典

python爬蟲(chóng)知識(shí)分享 ? 來(lái)源:python爬蟲(chóng)知識(shí)分享 ? 作者:python爬蟲(chóng)知識(shí)分享 ? 2022-03-29 17:39 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

通過(guò)序列生成字典

我們將下面的序列轉(zhuǎn)換為dict類(lèi)型。

lst=[('a',1),('b',2),('c',3)]

普通的寫(xiě)法

fork,vinlst:
dic[k]=v

pythonic的寫(xiě)法

利用字典推導(dǎo)式快速生成字典。

{k:vfork,vinlst}

key的默認(rèn)值

當(dāng)指定key不存在時(shí),將value設(shè)置為 0。

普通的寫(xiě)法

ifkeynotindct:
dct[key]=0

pythonic的寫(xiě)法

dct[key]=dct.get(key,0)

交換key與value

普通的寫(xiě)法

dic={'Python':1,'Java':2}
new_dic={}
fork,vindic.items():
new_dic[v]=k

pythonic的寫(xiě)法

dic={'Python':1,'Java':2}
new_dic={v:kfork,vindic.items()}

序列修改和初始化

示例數(shù)據(jù)

lst=[('a',1),('b',2),('c',3)]
dic={'a':[0]}

如果我們需要根據(jù)lst來(lái)更新dic中的數(shù)據(jù),當(dāng)key存在,則將value添加到原序列末尾,否則初始化value并用序列保存。

普通的寫(xiě)法

forkey,valueinlst:
ifkeyindic:
dic[key].append(value)
else:
dic[key]=[value]

pythonic的寫(xiě)法

for(key,value)inlst:
group=dic.setdefault(key,[])
group.append(value)
# dic:{'a':[0, 1], 'b':[2], 'c':[3]}

setdefault(key, default)會(huì)先判斷key是否存在,存在則返回dct[key], 不存在則把dct[key]設(shè)為 [] 并返回。

key,items的集合運(yùn)算

如果我們現(xiàn)在需要獲取兩個(gè)字典的key相交的部分的映射信息。

普通的寫(xiě)法

dic1={'Python':1,'Java':2,'C':3}
dic2={'Python':3,'Java':2,'C++':1}

new_dic={}
fork,vindic1.items():
ifkindic2.keys():
new_dic[k]=v
print(new_dic)

#{'Python':1,'Java':2}

pythonic的寫(xiě)法

dic1={'Python':1,'Java':2,'C':3}
dic2={'Python':3,'Java':2,'C++':1}

print({k:dic1[k]forkindic1.keys()&dic2.keys()})

#{'Python':1,'Java':2}

這里的dic1.keys() & dic2.keys()用到的就是keys()進(jìn)行集合運(yùn)算,items()同樣可以進(jìn)行集合運(yùn)算。

如果現(xiàn)在我們要獲取兩個(gè)字典中key,value完全相同的部分。

dic1={'Python':1,'Java':2,'C':3}
dic2={'Python':3,'Java':2,'C++':1}

print(dic1.items()&dic2.items())

#{('Java',2)}

靈活運(yùn)用 keys,items() 集合運(yùn)算的特性,可以快速提取我們想要的內(nèi)容。

按key或value對(duì)字典排序

使用sorted()函數(shù)快速實(shí)現(xiàn)對(duì)keyvalue的排序。

dic={'a':2,'b':1,'c':3,'d':0}
lst1=sorted(dic.items(),key=lambdax:x[0],reverse=False)
#[('a',2),('b',1),('c',3),('d',0)]
lst2=sorted(dic.items(),key=lambdax:x[1],reverse=False)
#[('d',0),('b',1),('a',2),('c',3)]
print('按照鍵降序:',{key:valueforkey,valueinlst1})
print('按照值降序:',{key:valueforkey,valueinlst2})

#按照鍵降序:{'a': 2, 'b': 1, 'c': 3, 'd':0}
#按照值降序:{'d':0, 'b': 1, 'a': 2, 'c': 3}

多個(gè)字典排序

如果一個(gè)序列中包含多個(gè)字典,現(xiàn)在要根據(jù)條件對(duì)這些字典繼續(xù)排序。同樣可以使用sorted()函數(shù)來(lái)實(shí)現(xiàn)。

dict_list=[
{'letter':'B','number':'2'},
{'letter':'A','number':'3'},
{'letter':'B','number':'1'}
]

#按letter排序
print(sorted(dict_list,
key=lambdadic:dic['letter']))
#按letter,number排序
print(sorted(dict_list,
key=lambdadic:(dic['letter'],dic['number'])))

#[{'letter':'A','number':'3'},{'letter':'B','number':'2'},{'letter':'B','number':'1'}]
#[{'letter':'A','number':'3'},{'letter':'B','number':'1'},{'letter':'B','number':'2'}]

當(dāng)然,如果你知道itemgetter()的話,上面的代碼就可以改變一下,執(zhí)行速度會(huì)更快。

fromoperatorimportitemgetter

print(sorted(dict_list,
key=itemgetter('letter')))
print(sorted(dict_list,
key=itemgetter('letter','number')))

itemgetter()獲取的不是值,而是定義了一個(gè)函數(shù),通過(guò)該函數(shù)作用到目標(biāo)對(duì)象上。
審核編輯:湯梓紅

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4400

    瀏覽量

    66389
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4848

    瀏覽量

    89001
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    canopen如何通過(guò)對(duì)象字典控制外設(shè)?

    各位大佬好,我在移植canopen的時(shí)候碰到一個(gè)疑問(wèn)。比如我修改對(duì)象字典2000,子索引為0這個(gè)目錄下的值,如何這個(gè)對(duì)象映射的是某個(gè)led燈的亮滅,輸入1為亮,0為滅。 問(wèn)題就是我發(fā)送報(bào)文之后會(huì)進(jìn)入
    發(fā)表于 09-11 06:04

    termux調(diào)試python猜數(shù)字游戲

    實(shí)現(xiàn)(Python版) ```python import random def guess_number(): # 生成隨機(jī)數(shù)字(1-100) secret_number
    發(fā)表于 08-29 17:15

    termux如何搭建python游戲

    模擬器,支持通過(guò)APT包管理器安裝軟件。搭建Python游戲開(kāi)發(fā)環(huán)境前需完成以下基礎(chǔ)配置: 1. 更換國(guó)內(nèi)源 為提升下載速度,需替換Termux默認(rèn)源為清華源,執(zhí)行以下命令: ```bash
    發(fā)表于 08-29 07:06

    基礎(chǔ)篇3:掌握Python中的條件語(yǔ)句與循環(huán)

    : print(\"你還很小。\") 循環(huán) 循環(huán)允許程序重復(fù)執(zhí)行一段代碼,直到滿足某個(gè)條件為止。Python中有幾種不同的循環(huán)結(jié)構(gòu)。 for循環(huán) for循環(huán)通常用于遍歷序列(如列表、元組
    發(fā)表于 07-03 16:13

    python入門(mén)圣經(jīng)-高清電子書(shū)(建議下載)

    和Pygal 等強(qiáng)大的Python 庫(kù)和工具介紹,以及列表、字典、if 語(yǔ)句、類(lèi)、文件與異常、代碼測(cè)試等內(nèi)容; 第二部分將理論付諸實(shí)踐,講解如何開(kāi)發(fā)三個(gè)項(xiàng)目,包括簡(jiǎn)單的Python 2D 游戲開(kāi)發(fā)如何利用數(shù)據(jù)
    發(fā)表于 04-10 16:53

    聲智APP通過(guò)北京市生成式人工智能服務(wù)登記

    近日,聲智APP已正式通過(guò)北京市第二批生成式人工智能服務(wù)登記,成為《生成式人工智能服務(wù)管理暫行辦法》(以下簡(jiǎn)稱(chēng)《辦法》)實(shí)施以來(lái),北京市累計(jì)已完成46款生成式人工智能服務(wù)登記中的重要一
    的頭像 發(fā)表于 03-19 16:33 ?729次閱讀

    ?Diffusion生成式動(dòng)作引擎技術(shù)解析

    Diffusion生成式動(dòng)作引擎 Diffusion生成式動(dòng)作引擎是一種基于擴(kuò)散模型(Diffusion Models)的生成式人工智能技術(shù),專(zhuān)注于生成連續(xù)、逼真的人類(lèi)動(dòng)作或動(dòng)畫(huà)
    的頭像 發(fā)表于 03-17 15:14 ?2527次閱讀

    Python中的迭代器與生成

    Python迭代器與生成器 列表生成式 列表生成式也叫做列表推導(dǎo)式,它本身還是列表,只不過(guò)它是根據(jù)我們定義的規(guī)則來(lái)生成一個(gè)真實(shí)的列表。 ?
    的頭像 發(fā)表于 02-20 10:43 ?572次閱讀

    開(kāi)源隨機(jī)數(shù)生成器庫(kù)OpenRNG助力實(shí)現(xiàn)移植到Arm平臺(tái)時(shí)的最佳性能

    OpenRNG 實(shí)現(xiàn)了多種生成器和分布方式。生成器算法可生成“看似隨機(jī)”并具有某些統(tǒng)計(jì)特性的序列,我們將在下文進(jìn)行討論。分布方式會(huì)將序列映射
    的頭像 發(fā)表于 02-08 09:24 ?1641次閱讀
    開(kāi)源隨機(jī)數(shù)<b class='flag-5'>生成</b>器庫(kù)OpenRNG助力實(shí)現(xiàn)移植到Arm平臺(tái)時(shí)的最佳性能

    使用Python實(shí)現(xiàn)xgboost教程

    使用Python實(shí)現(xiàn)XGBoost模型通常涉及以下幾個(gè)步驟:數(shù)據(jù)準(zhǔn)備、模型訓(xùn)練、模型評(píng)估和模型預(yù)測(cè)。以下是一個(gè)詳細(xì)的教程,指導(dǎo)你如何在Python中使用XGBoost。 1. 安裝XGBoost
    的頭像 發(fā)表于 01-19 11:21 ?1975次閱讀

    Python中dict支持多個(gè)key的方法

    ? 在Python中,字典(dict)是一種非常強(qiáng)大的數(shù)據(jù)結(jié)構(gòu),它允許我們通過(guò)鍵(key)來(lái)存儲(chǔ)和檢索值(value)。有時(shí)候,我們可能想要根據(jù)多個(gè)鍵來(lái)檢索或操作字典中的數(shù)據(jù)。雖然
    的頭像 發(fā)表于 11-29 15:59 ?702次閱讀

    RNN在圖片描述生成中的應(yīng)用

    輸入圖像的內(nèi)容。 RNN的基本原理 RNN是一種用于處理序列數(shù)據(jù)的神經(jīng)網(wǎng)絡(luò),它通過(guò)循環(huán)結(jié)構(gòu)來(lái)處理序列中的每個(gè)元素,并保持前一個(gè)元素的信息。RNN的主要特點(diǎn)是它能夠處理任意長(zhǎng)度的序列,并
    的頭像 發(fā)表于 11-15 09:58 ?1208次閱讀

    如何使用RNN進(jìn)行時(shí)間序列預(yù)測(cè)

    一種強(qiáng)大的替代方案,能夠?qū)W習(xí)數(shù)據(jù)中的復(fù)雜模式,并進(jìn)行準(zhǔn)確的預(yù)測(cè)。 RNN的基本原理 RNN是一種具有循環(huán)結(jié)構(gòu)的神經(jīng)網(wǎng)絡(luò),它能夠處理序列數(shù)據(jù)。在RNN中,每個(gè)輸入序列的元素都會(huì)通過(guò)一個(gè)或多個(gè)循環(huán)層,這些循環(huán)層可以捕獲時(shí)間
    的頭像 發(fā)表于 11-15 09:45 ?1188次閱讀

    如何使用Python構(gòu)建LSTM神經(jīng)網(wǎng)絡(luò)模型

    numpy tensorflow 2. 準(zhǔn)備數(shù)據(jù) LSTM模型通常用于序列數(shù)據(jù),比如時(shí)間序列預(yù)測(cè)或文本生成。這里我們以一個(gè)簡(jiǎn)單的時(shí)間序列預(yù)測(cè)為例。假
    的頭像 發(fā)表于 11-13 10:10 ?1985次閱讀

    如何使用 Llama 3 進(jìn)行文本生成

    使用LLaMA 3(Large Language Model Family of AI Alignment)進(jìn)行文本生成,可以通過(guò)以下幾種方式實(shí)現(xiàn),取決于你是否愿意在本地運(yùn)行模型或者使用現(xiàn)成的API
    的頭像 發(fā)表于 10-27 14:21 ?1436次閱讀