python中OrderedDict的使用方法詳解
很多人認(rèn)為python中的字典是無(wú)序的,因?yàn)樗前凑説ash來(lái)存儲(chǔ)的,但是python中有個(gè)模塊collections(英文,收集、集合),里面自帶了一個(gè)子類
OrderedDict,實(shí)現(xiàn)了對(duì)字典對(duì)象中元素的排序。請(qǐng)看下面的實(shí)例:
import collections
print "Regular dictionary"
d={}
d['a']='A'
d['b']='B'
d['c']='C'
for k,v in d.items():
print k,v
print "\nOrder dictionary"
d1 = collections.OrderedDict()
d1['a'] = 'A'
d1['b'] = 'B'
d1['c'] = 'C'
d1['1'] = '1'
d1['2'] = '2'
for k,v in d1.items():
print k,v
輸出:
Regular dictionary
a A
c C
b B
Order dictionary
a A
b B
c C
1 1
2 2
可以看到,同樣是保存了ABC等幾個(gè)元素,但是使用OrderedDict會(huì)根據(jù)放入元素的先后順序進(jìn)行排序。所以輸出的值是排好序的。
OrderedDict對(duì)象的字典對(duì)象,如果其順序不同那么Python也會(huì)把他們當(dāng)做是兩個(gè)不同的對(duì)象,請(qǐng)看事例:
print 'Regular dictionary:'
d2={}
d2['a']='A'
d2['b']='B'
d2['c']='C'
d3={}
d3['c']='C'
d3['a']='A'
d3['b']='B'
print d2 == d3
print '\nOrderedDict:'
d4=collections.OrderedDict()
d4['a']='A'
d4['b']='B'
d4['c']='C'
d5=collections.OrderedDict()
d5['c']='C'
d5['a']='A'
d5['b']='B'
print d1==d2
輸出:
Regular dictionary:
True
OrderedDict:
False
再看幾個(gè)例子:
dd = {'banana': 3, 'apple':4, 'pear': 1, 'orange': 2}
#按key排序
kd = collections.OrderedDict(sorted(dd.items(), key=lambda t: t[0]))
print kd
#按照value排序
vd = collections.OrderedDict(sorted(dd.items(),key=lambda t:t[1]))
print vd
#輸出
OrderedDict([('apple', 4), ('banana', 3), ('orange', 2), ('pear', 1)])
OrderedDict([('pear', 1), ('orange', 2), ('banana', 3), ('apple', 4)])
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
PySpark中RDD的數(shù)據(jù)輸出問(wèn)題詳解
RDD是 Spark 中最基礎(chǔ)的抽象,它表示了一個(gè)可以并行操作的、不可變得、被分區(qū)了的元素集合,這篇文章主要介紹了PySpark中RDD的數(shù)據(jù)輸出詳解,需要的朋友可以參考下2023-01-01
解決python讀取幾千萬(wàn)行的大表內(nèi)存問(wèn)題
今天小編就為大家分享一篇解決python讀取幾千萬(wàn)行的大表內(nèi)存問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-06-06
Python?RawString與open文件的newline換行符遇坑解決
這篇文章主要為大家介紹了Python?RawString與open文件的newline換行符遇坑解決示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
Python實(shí)現(xiàn)向QQ群成員自動(dòng)發(fā)郵件的方法
2014-11-11
Python使用Vagrant搭建開(kāi)發(fā)環(huán)境的具體步驟
使用 Vagrant 搭建開(kāi)發(fā)環(huán)境是一個(gè)非常方便的方式,它可以幫助你快速創(chuàng)建、配置和管理虛擬機(jī),確保開(kāi)發(fā)環(huán)境的一致性,以下是使用 Vagrant 搭建開(kāi)發(fā)環(huán)境的具體步驟,需要的朋友可以參考下2024-09-09

