" />

亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python字典使用技巧詳解

 更新時間:2022年11月14日 10:47:47   作者:趙卓不凡  
Python 中字典和集合也是非常相近的概念,而且從外觀看上去,也有那么一絲絲的相似。本文將從字典基本知識入手,為你展開字典類型數(shù)據(jù)的各個知識點,需要的可以參考一下

1. 引言

在日常工作中,大家都需要進行字典的相關操作,對于某些初學者,經(jīng)常會寫一堆繁瑣的代碼來實現(xiàn)某項簡單的功能。本篇文章重點介紹一些在Python中關于字典的一些簡單技巧,熟練掌握相關技巧可以極大提升大家的工作效率。

閑話少說,我們直接開始吧!

2. 使用union操作合并字典

當然我們可以使用for循環(huán)來組合不同字典中的元素,但是在使用Python3.9之后,我們可以方便的使用union操作來進行字典的合并。

樣例代碼如下:

cities_us = {'New York City': 'US', 'Los Angeles': 'US'}
cities_uk = {'London': 'UK', 'Birmingham': 'UK'}
cities = cities_us|cities_uk
print(cities)
# {'New York City': 'US', 'Los Angeles': 'US', 'London': 'UK', 'Birmingham': 'UK'}

當然我們也可以使用|= 來實現(xiàn),如下:

cities_us = {'New York City': 'US', 'Los Angeles': 'US'}
cities_uk = {'London': 'UK', 'Birmingham': 'UK'}
cities_us |= cities_uk
print(cities_us)
# {'New York City': 'US', 'Los Angeles': 'US', 'London': 'UK', 'Birmingham': 'UK'}

3. 使用解包操作合并字典

考慮到使用union操作的簡潔性,我經(jīng)常盡可能的使用該操作進行字典的合并操作。但是,如果我們使用的是Python3.9以下的版本,有沒有其他簡潔的方式來實現(xiàn)上述字典合并功能呢?

當然是存在的,此時推薦使用解包操作來實現(xiàn)。

樣例如下:

cities_1 = {'New York City': 'US', 'Los Angeles': 'US'}
cities_2 = {'London': 'UK', 'Birmingham': 'UK'}
cities = {**cities_1, **cities_2}
print(cities)
# {'New York City': 'US', 'Los Angeles': 'US', 'London': 'UK', 'Birmingham': 'UK'}

4. 使用字典生成式

與Python中的列表生成式一樣,字典生成式也是創(chuàng)建字典的一種簡便的方法,它為我們提供了篩選數(shù)據(jù)的靈活性。

字典生成式的一般范式為:

D = {<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->key: value for key,value in iterable (if condition)}

我們可以通過下方例子來體檢一下字典生成式的強大,如下:

cities = ['London', 'New York', 'Tokyo', 'Cambridge', 'Oxford']
countries = ['UK', 'US', 'Japan', 'UK', 'UK']
uk_cities = {city: country for city, country in zip(cities, countries) if country == 'UK'}
print(uk_cities)
# {'London': 'UK', 'Cambridge': 'UK', 'Oxford': 'UK'}

5. 字典中key-value互換

在某些情形下,我們需要互換字典中的key-value,當然有各種各樣的策略來實現(xiàn)上述功能。

以下是我比較推薦的兩種實現(xiàn),如下:

cities = {<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->'London': 'UK', 'Tokyo': 'Japan', 'New York': 'US'}

方案一:

reversed_cities = {v: k for k, v in cities.items()}
print(reversed_cities)
# {'UK': 'London', 'Japan': 'Tokyo', 'US': 'New York'}

方案二:

reversed_cities = dict(zip(cities.values(), cities.keys()))
print(reversed_cities)

6. 列表轉為字典

列表也是Python中最常使用的數(shù)據(jù)結構之一,在某些情形下,我們需要將列表轉化為字典。這里我們分情況來討論:

假如列表中包含key和value,此時可以直接使用dict來生成相應的對象,如下:

cities = [('London', 'UK'), ('New York', 'US'), ('Tokyo', 'Japan')]
d_cities = dict(cities)
print(d_cities)
# {'London': 'UK', 'New York': 'US', 'Tokyo': 'Japan'}

如果列表中只含有key,需要統(tǒng)一賦值某value,此時一般使用dict.fromkeys 方法來實現(xiàn),如下:

cities = ['London', 'Leeds', 'Birmingham']
d_cities = dict.fromkeys(cities,'UK') # set the default value to 'UK' 
print(d_cities)
# {'London': 'UK', 'Leeds': 'UK', 'Birmingham': 'UK'}

7. 字典按照value來排序

使用一行代碼來實現(xiàn)字典按照value排序,可以借助lambda來實現(xiàn),樣例如下:

cities = {'London': '2', 'Tokyo': '3', 'New York': '1'}
print(sorted(cities.items(),key=lambda d:d[1]))
# [('New York', '1'), ('London', '2'), ('Tokyo', '3')]

8. 使用Counter

如果我們需要知道在字符串中每個字母使用了多少次,最直觀的方法可能是編寫一個for循環(huán)來遍歷所有字母并進行統(tǒng)計。

但如果我們知道Counter,則上述任務將變得異常簡單:

from collections import Counter
city = "Yang Zhou"
chars = Counter(city)
print(chars)
# Counter({'Y': 1, 'a': 1, 'n': 1, 'g': 1, ' ': 1, 'Z': 1, 'h': 1, 'o': 1, 'u': 1})

顧名思義,Counter對象幫助我們完成字符統(tǒng)計部分,并將結果保存為字典。如果我們能在類似的使用場景中記住這個特殊的dict,那么可以節(jié)省大量的代碼編寫時間。

9. 總結

本文重點介紹了Python中字典操作的相關技巧,并針對性的給出了相關示例和代碼實現(xiàn)。最后,送給大家兩句話共勉:

學習Python意味著我們可以編寫返回正確結果的程序。

掌握Python意味著我們可以以優(yōu)雅、整潔和Pythonic的方式編寫相同的程序。

到此這篇關于Python字典使用技巧詳解的文章就介紹到這了,更多相關Python字典內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 使用Python實現(xiàn)博客上進行自動翻頁

    使用Python實現(xiàn)博客上進行自動翻頁

    這篇文章主要介紹了使用Python實現(xiàn)博客上進行自動翻頁,需要的朋友可以參考下
    2017-08-08
  • python 字符串格式化的示例

    python 字符串格式化的示例

    這篇文章主要介紹了python 字符串格式化的示例,幫助大家更好的理解和使用python處理字符串,感興趣的朋友可以了解下
    2020-09-09
  • python3 selenium自動化 下拉框定位的例子

    python3 selenium自動化 下拉框定位的例子

    今天小編就為大家分享一篇python3 selenium自動化 下拉框定位的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • Django 權限管理(permissions)與用戶組(group)詳解

    Django 權限管理(permissions)與用戶組(group)詳解

    這篇文章主要介紹了Django 權限管理(permissions)與用戶組(group)詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • python計算牛頓迭代多項式實例分析

    python計算牛頓迭代多項式實例分析

    這篇文章主要介紹了python計算牛頓迭代多項式的方法,涉及Python數(shù)學運算的相關技巧,需要的朋友可以參考下
    2015-05-05
  • Python?中enum的使用方法總結

    Python?中enum的使用方法總結

    這篇文章主要介紹了Python?中enum的使用方法總結,枚舉在許多編程語言中常被表示為一種基礎的數(shù)據(jù)結構使用,下文更多詳細內(nèi)容需要的小伙伴可以參考一下
    2022-03-03
  • 對于Python中RawString的理解介紹

    對于Python中RawString的理解介紹

    下面小編就為大家?guī)硪黄獙τ赑ython中RawString的理解介紹。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • 如何用python處理excel表格

    如何用python處理excel表格

    在本篇文章里小編給大家整理了關于python處理excel表格的詳細步驟內(nèi)容,需要的朋友們可以參考下。
    2020-06-06
  • Python hashlib模塊的使用示例

    Python hashlib模塊的使用示例

    這篇文章主要介紹了Python hashlib模塊的相關資料,幫助大家更好的理解和學習python,感興趣的朋友可以了解下
    2020-10-10
  • PyGame貪吃蛇的實現(xiàn)代碼示例

    PyGame貪吃蛇的實現(xiàn)代碼示例

    貪吃蛇是款經(jīng)典游戲,本文將帶你一步步用python語言實現(xiàn)一個貪吃蛇小游戲,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11

最新評論