日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

python中字典数据的特点_Python字典(Dictionary) 在数据分析中的操作

發(fā)布時(shí)間:2024/3/7 python 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python中字典数据的特点_Python字典(Dictionary) 在数据分析中的操作 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

今天來聊聊python中的字典在數(shù)據(jù)分析中的應(yīng)用,為了貼近實(shí)戰(zhàn)關(guān)于簡單結(jié)構(gòu)的字典就略過。

今天要聊的字典結(jié)構(gòu)是如下這類復(fù)雜結(jié)構(gòu):

{

"id": "2406124091",

"type": "node",

"visible":"true",

"created": {

"version":"2",

"changeset":"17206049",

"timestamp":"2013-08-03T16:43:42Z",

"user":"linuxUser16",

"uid":"1219059"

},

"pos": [41.9757030, -87.6921867],

"address": {

"housenumber": "5157",

"postcode": "60625",

"street": "North Lincoln Ave"

},

"amenity": "restaurant",

"cuisine": "mexican",

"name": "La Cabana De Don Luis",

"phone": "1 (773)-271-5176"

}

這類數(shù)據(jù)結(jié)構(gòu)是為了方便寫成JSON,或者存入MongoDB使用而存在的。為了便于理解和掌握這種復(fù)雜字典的操作方式,我們采取幾個有趣的實(shí)驗(yàn),來感受一下:

一、復(fù)雜結(jié)構(gòu)字典是否可以拆分成簡單結(jié)構(gòu)的字典

如果把這個復(fù)雜結(jié)構(gòu)拆分成幾個結(jié)構(gòu)簡單的小字典或者列表,那么處理起來就會簡單許多:

##第一個小字典

{"id": "2406124091",

"type": "node",

"visible":"true"}

##第二個小字典

{"version":"2",

"changeset":"17206049",

"timestamp":"2013-08-03T16:43:42Z",

"user":"linuxUser16",

"uid":"1219059"}

##一個小列表

[41.9757030, -87.6921867]

##第三個小字典

{"housenumber": "5157",

"postcode": "60625",

"street": "North Lincoln Ave"}

##第四個小字典

{"amenity": "restaurant",

"cuisine": "mexican",

"name": "La Cabana De Don Luis",

"phone": "1 (773)-271-5176"}

接下來,我們看看用哪種方法可以進(jìn)行合并:

d1 = {"id": "2406124091",

"type": "node",

"visible":"true"}

d2 = {"version":"2",

"changeset":"17206049",

"timestamp":"2013-08-03T16:43:42Z",

"user":"linuxUser16",

"uid":"1219059"}

l1 = [41.9757030, -87.6921867]

d3 = {"housenumber": "5157",

"postcode": "60625",

"street": "North Lincoln Ave"}

d4 = {"amenity": "restaurant",

"cuisine": "mexican",

"name": "La Cabana De Don Luis",

"phone": "1 (773)-271-5176"}

d = {d1,d2,l1,d3,d4}

#Traceback (most recent call last):

#

# File "", line 1, in

# d = {d1,d2,l1,d3,d4}

#

#TypeError: unhashable type: 'dict'

###簡單粗暴的合并,可惜這樣的合并是不可行的

###嘗試加上標(biāo)簽后進(jìn)行合并

d = d1

d['created'] = d2

d['pos'] = l1

d['address'] = d3

d = dict(d,**d4)

pprint.pprint(d)

#{'address': {'housenumber': '5157',

# 'postcode': '60625',

# 'street': 'North Lincoln Ave'},

# 'amenity': 'restaurant',

# 'created': {'changeset': '17206049',

# 'timestamp': '2013-08-03T16:43:42Z',

# 'uid': '1219059',

# 'user': 'linuxUser16',

# 'version': '2'},

# 'cuisine': 'mexican',

# 'id': '2406124091',

# 'name': 'La Cabana De Don Luis',

# 'phone': '1 (773)-271-5176',

# 'pos': [41.975703, -87.6921867],

# 'type': 'node',

# 'visible': 'true'}

###成功完成復(fù)雜字典的合并,但是有個問題,順序不對。在一些特定應(yīng)用場景中,字典中的數(shù)據(jù)結(jié)構(gòu)

###是被嚴(yán)格要求的。那么需要繼續(xù)進(jìn)行帶有順序要求的控制。

d = {'created':d2,'pos':l1,'address':d3}

pprint.pprint(d)

#{'address': {'housenumber': '5157',

# 'postcode': '60625',

# 'street': 'North Lincoln Ave'},

# 'created': {'changeset': '17206049',

# 'timestamp': '2013-08-03T16:43:42Z',

# 'uid': '1219059',

# 'user': 'linuxUser16',

# 'version': '2'},

# 'pos': [41.975703, -87.6921867]}

#

###成功完成了按順序的合并,但是d1和d4的字典卻無法進(jìn)行可控的合并,采用dict()函數(shù)合并后,

###元素會添加在最后,這就又回到最初的情況

二、由上一個實(shí)驗(yàn)可知,兩個字典直接合并可行,但結(jié)構(gòu)順序無法控制,需要對一些結(jié)構(gòu)進(jìn)行再分解。

d1 = {"id": "2406124091"}

d2 = {"type": "node"}

d3 = {"visible":"true"}

d4 = {"version":"2",

"changeset":"17206049",

"timestamp":"2013-08-03T16:43:42Z",

"user":"linuxUser16",

"uid":"1219059"}

l1 = [41.9757030, -87.6921867]

d5 = {"housenumber": "5157",

"postcode": "60625",

"street": "North Lincoln Ave"}

d6 = {"amenity": "restaurant"}

d7 = {"cuisine": "mexican"}

d8 ={"name": "La Cabana De Don Luis"}

d9 = {"phone": "1 (773)-271-5176"}

拆分完之后是這個樣子:

d = {'id':d1,'type':d2,'visible':d3,'created':d4,'pos':l1,'address':d5,

'amenity':d6,'cuisine':d7,'name':d8,'phone':d9}

import pprint

pprint.pprint(d)

#{'address': {'housenumber': '5157',

# 'postcode': '60625',

# 'street': 'North Lincoln Ave'},

# 'amenity': {'amenity': 'restaurant'},

# 'created': {'changeset': '17206049',

# 'timestamp': '2013-08-03T16:43:42Z',

# 'uid': '1219059',

# 'user': 'linuxUser16',

# 'version': '2'},

# 'cuisine': {'cuisine': 'mexican'},

# 'id': {'id': '2406124091'},

# 'name': {'name': 'La Cabana De Don Luis'},

# 'phone': {'phone': '1 (773)-271-5176'},

# 'pos': [41.975703, -87.6921867],

# 'type': {'type': 'node'},

# 'visible': {'visible': 'true'}}

###沒有出現(xiàn)我們想要的結(jié)果,除了結(jié)構(gòu)是混亂的之外,重新構(gòu)建的字典中,數(shù)據(jù)結(jié)構(gòu)也出現(xiàn)的明顯的

###錯誤。嘗試另外一種構(gòu)建方式:

d = {d1,d2,d3,'created':d4,'pos':l1,'address':d5,d6,d7,d8,d9}

d = {d1,d2,d3,d4,l1,d5,d6,d7,d8,d9}

#Traceback (most recent call last):

#

# File "", line 1, in

# d = {d1,d2,d3,d4,l1,d5,d6,d7,d8,d9}

#

#TypeError: unhashable type: 'dict'

d = {d1,d2,d3,d4,'pos':l1,d5,d6,d7,d8,d9}

# File "", line 1

# d = {d1,d2,d3,d4,'pos':l1,d5,d6,d7,d8,d9}

# ^

#SyntaxError: invalid syntax

#

###這種構(gòu)建方式,過于異想天開了,語法是錯誤的。

###dict()函數(shù)合并的方式我不打算嘗試了,應(yīng)為其中的l1是list,這個是無法用這個函數(shù)合并的。

三、直接固定字典的格式,然后對其填充數(shù)值或者內(nèi)容

d = {

"id": "",

"type": "",

"visible":"",

"created": {

"version":"",

"changeset":"",

"timestamp":"",

"user":"",

"uid":""

},

"pos": [0,0],

"address": {

"housenumber": "",

"postcode": "",

"street": ""

},

"amenity": "",

"cuisine": "",

"name": "",

"phone": ""

}

d['id']='2406124091'

d['address']['housenumber']='123456'

pprint.pprint(d['id'])

#'2406124091'

pprint.pprint(d['address'])

#{'housenumber': '123456', 'postcode': '', 'street': ''}

###成功完成寫入操作,這種方式需要配合循環(huán)和條件判斷語句使用。好處是,讓數(shù)據(jù)結(jié)構(gòu)得以固定。

最后,編程這事,沒有唯一答案,條條道路通羅馬。找到自己最喜歡最順手的方式是最好的。

其實(shí)還有一種方法是使用eval()函數(shù),但介于廣大高手們痛恨和鄙視使用該函數(shù),所以這里就不在對這個函數(shù)的用法進(jìn)行探討。

總結(jié)

以上是生活随笔為你收集整理的python中字典数据的特点_Python字典(Dictionary) 在数据分析中的操作的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。