python中字典的一些用法,python中字典的方法有哪些

本文目錄一覽:

python中字典的使用方法怎麼樣的

dict全稱dictionary,使用鍵-值(key-value)存儲,具有極快的查找速度。

舉個例子,假設要根據同學的名字查找對應的成績,如果用list實現,需要兩個list:

names = [‘Michael’, ‘Bob’, ‘Tracy’]

scores = [95, 75, 85]

給定一個名字,要查找對應的成績,就先要在names中找到對應的位置,再從scores取出對應的成績,list越長,耗時越長。

如果用dict實現,只需要一個“名字”-“成績”的對照表,直接根據名字查找成績,無論這個表有多大,查找速度都不會變慢。用Python寫一個dict如下:

d = {‘Michael’: 95, ‘Bob’: 75, ‘Tracy’: 85}

d[‘Michael’]

95

把數據放入dict的方法,除了初始化時指定外,還可以通過key放入:

d[‘Adam’] = 67

d[‘Adam’]

67

由於一個key只能對應一個value,所以,多次對一個key放入value,後面的值會把前面的值衝掉:

d[‘Jack’] = 90

d[‘Jack’]

90

d[‘Jack’] = 88

d[‘Jack’]

88

如果key不存在,dict就會報錯:

d[‘Thomas’]

Traceback (most recent call last):

File “”, line 1, in KeyError: ‘Thomas’

要避免key不存在的錯誤,有兩種辦法,一是通過in判斷key是否存在:

‘Thomas’ in dFalse

二是通過dict提供的get()方法,如果key不存在,可以返回None,或者自己指定的value:

d.get(‘Thomas’)

d.get(‘Thomas’, -1)

-1

要刪除一個key,用pop(key)方法,對應的value也會從dict中刪除:

d.pop(‘Bob’)

75

d

{‘Michael’: 95, ‘Tracy’: 85}

python中字典的使用方法怎麼樣的?

字典理解如下

另一個非常有用的 Python 內建數據類型是 字典 (參見 Mapping Types — dict )。字典在某些語言中可能稱為 聯合內存 ( associative memories )或 聯合數組 ( associative arrays )。序列是以連續的整數為索引,與此不同的是,字典以 關鍵字 為索引,關鍵字可以是任意不可變類型,通常用字符串或數值。如果元組中只包含字符串和數字,它可以作為關鍵字,如果它直接或間接的包含了可變對象,就不能當作關鍵字。不能用列表做關鍵字,因為列表可以用索引、切割或者 append() 和 extend() 等方法改變。

理解字典的最佳方式是把它看作無序的鍵: 值對 (key:value 對)集合,鍵必須是互不相同的(在同一個字典之內)。一對大括號創建一個空的字典: {} 。初始化列表時,在大括號內放置一組逗號分隔的鍵:值對,這也是字典輸出的方式。

字典的主要操作是依據鍵來存儲和析取值。也可以用 del 來刪除鍵:值對(key:value)。如果你用一個已經存在的關鍵字存儲值,以前為該關鍵字分配的值就會被遺忘。試圖從一個不存在的鍵中取值會導致錯誤。

對一個字典執行 list(d.keys()) 將返回一個字典中所有關鍵字組成的無序列表(如果你想要排序,只需使用 sorted(d.keys()) )。[2] 使用 in 關鍵字(指Python語法)可以檢查字典中是否存在某個關鍵字(指字典)。

python字典操作函數

字典是一種通過名字或者關鍵字引用的得數據結構,其鍵可以是數字、字符串、元組,這種結構類型也稱之為映射。字典類型是Python中唯一內建的映射類型,基本的操作包括如下:

(1)len():返回字典中鍵—值對的數量;

(2)d[k]:返回關鍵字對於的值;

(3)d[k]=v:將值關聯到鍵值k上;

(4)del d[k]:刪除鍵值為k的項;

(5)key in d:鍵值key是否在d中,是返回True,否則返回False。

(6)clear函數:清除字典中的所有項

(7)copy函數:返回一個具有相同鍵值的新字典;deepcopy()函數使用深複製,複製其包含所有的值,這個方法可以解決由於副本修改而使原始字典也變化的問題

(8)fromkeys函數:使用給定的鍵建立新的字典,鍵默認對應的值為None

(9)get函數:訪問字典成員

(10)has_key函數:檢查字典中是否含有給出的鍵

(11)items和iteritems函數:items將所有的字典項以列表方式返回,列表中項來自(鍵,值),iteritems與items作用相似,但是返回的是一個迭代器對象而不是列表

(12)keys和iterkeys:keys將字典中的鍵以列表形式返回,iterkeys返回鍵的迭代器

(13)pop函數:刪除字典中對應的鍵

(14)popitem函數:移出字典中的項

(15)setdefault函數:類似於get方法,獲取與給定鍵相關聯的值,也可以在字典中不包含給定鍵的情況下設定相應的鍵值

(16)update函數:用一個字典更新另外一個字典

(17) values和itervalues函數:values以列表的形式返回字典中的值,itervalues返回值得迭代器,由於在字典中值不是唯一的,所以列表中可以包含重複的元素

一、字典的創建

1.1 直接創建字典

d={‘one’:1,’two’:2,’three’:3}

printd

printd[‘two’]

printd[‘three’]

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘three’:3,’two’:2,’one’:1}

1.2 通過dict創建字典

# _*_ coding:utf-8 _*_

items=[(‘one’,1),(‘two’,2),(‘three’,3),(‘four’,4)]

printu’items中的內容:’

printitems

printu’利用dict創建字典,輸出字典內容:’

d=dict(items)

printd

printu’查詢字典中的內容:’

printd[‘one’]

printd[‘three’]

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

items中的內容:

[(‘one’,1), (‘two’,2), (‘three’,3), (‘four’,4)]

利用dict創建字典,輸出字典內容:

{‘four’:4,’three’:3,’two’:2,’one’:1}

查詢字典中的內容:

或者通過關鍵字創建字典

# _*_ coding:utf-8 _*_

d=dict(one=1,two=2,three=3)

printu’輸出字典內容:’

printd

printu’查詢字典中的內容:’

printd[‘one’]

printd[‘three’]

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

輸出字典內容:

{‘three’:3,’two’:2,’one’:1}

查詢字典中的內容:

二、字典的格式化字符串

# _*_ coding:utf-8 _*_

d={‘one’:1,’two’:2,’three’:3,’four’:4}

printd

print”three is %(three)s.”%d

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘four’:4,’three’:3,’two’:2,’one’:1}

threeis3.

三、字典方法

3.1 clear函數:清除字典中的所有項

# _*_ coding:utf-8 _*_

d={‘one’:1,’two’:2,’three’:3,’four’:4}

printd

d.clear()

printd

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘four’:4,’three’:3,’two’:2,’one’:1}

{}

請看下面兩個例子

3.1.1

# _*_ coding:utf-8 _*_

d={}

dd=d

d[‘one’]=1

d[‘two’]=2

printdd

d={}

printd

printdd

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘two’:2,’one’:1}

{}

{‘two’:2,’one’:1}

3.1.2

# _*_ coding:utf-8 _*_

d={}

dd=d

d[‘one’]=1

d[‘two’]=2

printdd

d.clear()

printd

printdd

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘two’:2,’one’:1}

{}

{}

3.1.2與3.1.1唯一不同的是在對字典d的清空處理上,3.1.1將d關聯到一個新的空字典上,這種方式對字典dd是沒有影響的,所以在字典d被置空後,字典dd裡面的值仍舊沒有變化。但是在3.1.2中clear方法清空字典d中的內容,clear是一個原地操作的方法,使得d中的內容全部被置空,這樣dd所指向的空間也被置空。

3.2 copy函數:返回一個具有相同鍵值的新字典

# _*_ coding:utf-8 _*_

x={‘one’:1,’two’:2,’three’:3,’test’:[‘a’,’b’,’c’]}

printu’初始X字典:’

printx

printu’X複製到Y:’

y=x.copy()

printu’Y字典:’

printy

y[‘three’]=33

printu’修改Y中的值,觀察輸出:’

printy

printx

printu’刪除Y中的值,觀察輸出’

y[‘test’].remove(‘c’)

printy

printx

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

初始X字典:

{‘test’: [‘a’,’b’,’c’],’three’:3,’two’:2,’one’:1}

X複製到Y:

Y字典:

{‘test’: [‘a’,’b’,’c’],’one’:1,’three’:3,’two’:2}

修改Y中的值,觀察輸出:

{‘test’: [‘a’,’b’,’c’],’one’:1,’three’:33,’two’:2}

{‘test’: [‘a’,’b’,’c’],’three’:3,’two’:2,’one’:1}

刪除Y中的值,觀察輸出

{‘test’: [‘a’,’b’],’one’:1,’three’:33,’two’:2}

{‘test’: [‘a’,’b’],’three’:3,’two’:2,’one’:1}

註:在複製的副本中對值進行替換後,對原來的字典不產生影響,但是如果修改了副本,原始的字典也會被修改。deepcopy函數使用深複製,複製其包含所有的值,這個方法可以解決由於副本修改而使原始字典也變化的問題。

# _*_ coding:utf-8 _*_

fromcopyimportdeepcopy

x={}

x[‘test’]=[‘a’,’b’,’c’,’d’]

y=x.copy()

z=deepcopy(x)

printu’輸出:’

printy

printz

printu’修改後輸出:’

x[‘test’].append(‘e’)

printy

printz

運算輸出:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

輸出:

{‘test’: [‘a’,’b’,’c’,’d’]}

{‘test’: [‘a’,’b’,’c’,’d’]}

修改後輸出:

{‘test’: [‘a’,’b’,’c’,’d’,’e’]}

{‘test’: [‘a’,’b’,’c’,’d’]}

3.3 fromkeys函數:使用給定的鍵建立新的字典,鍵默認對應的值為None

# _*_ coding:utf-8 _*_

d=dict.fromkeys([‘one’,’two’,’three’])

printd

運算輸出:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘three’:None,’two’:None,’one’:None}

或者指定默認的對應值

# _*_ coding:utf-8 _*_

d=dict.fromkeys([‘one’,’two’,’three’],’unknow’)

printd

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘three’:’unknow’,’two’:’unknow’,’one’:’unknow’}

3.4 get函數:訪問字典成員

# _*_ coding:utf-8 _*_

d={‘one’:1,’two’:2,’three’:3}

printd

printd.get(‘one’)

printd.get(‘four’)

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘three’:3,’two’:2,’one’:1}

1

None

註:get函數可以訪問字典中不存在的鍵,當該鍵不存在是返回None

3.5 has_key函數:檢查字典中是否含有給出的鍵

# _*_ coding:utf-8 _*_

d={‘one’:1,’two’:2,’three’:3}

printd

printd.has_key(‘one’)

printd.has_key(‘four’)

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘three’:3,’two’:2,’one’:1}

True

False

3.6 items和iteritems函數:items將所有的字典項以列表方式返回,列表中項來自(鍵,值),iteritems與items作用相似,但是返回的是一個迭代器對象而不是列表

# _*_ coding:utf-8 _*_

d={‘one’:1,’two’:2,’three’:3}

printd

list=d.items()

forkey,valueinlist:

  printkey,’:’,value

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘three’:3,’two’:2,’one’:1}

three :3

two :2

one :1

# _*_ coding:utf-8 _*_

d={‘one’:1,’two’:2,’three’:3}

printd

it=d.iteritems()

fork,vinit:

  print”d[%s]=”%k,v

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘three’:3,’two’:2,’one’:1}

d[three]=3

d[two]=2

d[one]=1

3.7 keys和iterkeys:keys將字典中的鍵以列表形式返回,iterkeys返回鍵的迭代器

# _*_ coding:utf-8 _*_

d={‘one’:1,’two’:2,’three’:3}

printd

printu’keys方法:’

list=d.keys()

printlist

printu’\niterkeys方法:’

it=d.iterkeys()

forxinit:

  printx

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘three’:3,’two’:2,’one’:1}

keys方法:

[‘three’,’two’,’one’]

iterkeys方法:

three

two

one

3.8 pop函數:刪除字典中對應的鍵

# _*_ coding:utf-8 _*_

d={‘one’:1,’two’:2,’three’:3}

printd

d.pop(‘one’)

printd

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘three’:3,’two’:2,’one’:1}

{‘three’:3,’two’:2}

3.9 popitem函數:移出字典中的項

# _*_ coding:utf-8 _*_

d={‘one’:1,’two’:2,’three’:3}

printd

d.popitem()

printd

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘three’:3,’two’:2,’one’:1}

{‘two’:2,’one’:1}

3.10 setdefault函數:類似於get方法,獲取與給定鍵相關聯的值,也可以在字典中不包含給定鍵的情況下設定相應的鍵值

# _*_ coding:utf-8 _*_

d={‘one’:1,’two’:2,’three’:3}

printd

printd.setdefault(‘one’,1)

printd.setdefault(‘four’,4)

printd

運算結果:

{‘three’:3,’two’:2,’one’:1}

{‘four’:4,’three’:3,’two’:2,’one’:1}

3.11 update函數:用一個字典更新另外一個字典

# _*_ coding:utf-8 _*_

d={

  ‘one’:123,

  ‘two’:2,

  ‘three’:3

  }

printd

x={‘one’:1}

d.update(x)

printd

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

{‘three’:3,’two’:2,’one’:123}

{‘three’:3,’two’:2,’one’:1}

3.12 values和itervalues函數:values以列表的形式返回字典中的值,itervalues返回值得迭代器,由於在字典中值不是唯一的,所以列表中可以包含重複的元素

# _*_ coding:utf-8 _*_

d={

  ‘one’:123,

  ‘two’:2,

  ‘three’:3,

  ‘test’:2

  }

printd.values()

運算結果:

=======RESTART: C:\Users\Mr_Deng\Desktop\test.py=======

[2,3,2,123]

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/247352.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 13:22
下一篇 2024-12-12 13:23

相關推薦

  • Python列表中負數的個數

    Python列表是一個有序的集合,可以存儲多個不同類型的元素。而負數是指小於0的整數。在Python列表中,我們想要找到負數的個數,可以通過以下幾個方面進行實現。 一、使用循環遍歷…

    編程 2025-04-29
  • Python計算陽曆日期對應周幾

    本文介紹如何通過Python計算任意陽曆日期對應周幾。 一、獲取日期 獲取日期可以通過Python內置的模塊datetime實現,示例代碼如下: from datetime imp…

    編程 2025-04-29
  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • 如何查看Anaconda中Python路徑

    對Anaconda中Python路徑即conda環境的查看進行詳細的闡述。 一、使用命令行查看 1、在Windows系統中,可以使用命令提示符(cmd)或者Anaconda Pro…

    編程 2025-04-29
  • Python程序需要編譯才能執行

    Python 被廣泛應用於數據分析、人工智能、科學計算等領域,它的靈活性和簡單易學的性質使得越來越多的人喜歡使用 Python 進行編程。然而,在 Python 中程序執行的方式不…

    編程 2025-04-29
  • Python字典去重複工具

    使用Python語言編寫字典去重複工具,可幫助用戶快速去重複。 一、字典去重複工具的需求 在使用Python編寫程序時,我們經常需要處理數據文件,其中包含了大量的重複數據。為了方便…

    編程 2025-04-29
  • 蝴蝶優化算法Python版

    蝴蝶優化算法是一種基於仿生學的優化算法,模仿自然界中的蝴蝶進行搜索。它可以應用於多個領域的優化問題,包括數學優化、工程問題、機器學習等。本文將從多個方面對蝴蝶優化算法Python版…

    編程 2025-04-29
  • python強行終止程序快捷鍵

    本文將從多個方面對python強行終止程序快捷鍵進行詳細闡述,並提供相應代碼示例。 一、Ctrl+C快捷鍵 Ctrl+C快捷鍵是在終端中經常用來強行終止運行的程序。當你在終端中運行…

    編程 2025-04-29
  • Python清華鏡像下載

    Python清華鏡像是一個高質量的Python開發資源鏡像站,提供了Python及其相關的開發工具、框架和文檔的下載服務。本文將從以下幾個方面對Python清華鏡像下載進行詳細的闡…

    編程 2025-04-29

發表回復

登錄後才能評論