国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

Python數據結構dict常用操作代碼實例

瀏覽:3日期:2022-08-02 15:37:05

dict是python中的常用數據結構,應該盡量掌握其使用方法

字典是另一種可變容器模型,且可存儲任意類型對象。

字典的每個鍵值 key=>value 對用冒號 : 分割,每個鍵值對之間用逗號 , 分割,整個字典包括在花括號 {} 中

代碼如下

''' 初始化一個dict的四種方式: 1. dict() -> 創建一個空的dict 2. dict(mapping) -> new dictionary initialized from a mapping object’s (key, value) pairs 3. dict(iterable) -> new dictionary initialized as if via: d = {} for k, v in iterable: d[k] = v 4. dict(**kwargs) -> new dictionary initialized with the name=value pairs in the keyword argument list. For example: dict(one=1, two=2) '''# 第一種方式d = dict()# 第二種方式# d = {'person': {'name': 'admin', 'age': 12},# 'animal': {'name': 'gaodan', 'age': 3},# }# 第三種方式d = dict({'name': 'admin'})print(d)# 第四種方式d = dict(name=’admin’, age=12)print(type(d))print('原字典:%s' % d) # {’name’: ’admin’, ’age’: 12}# clear, 清空# d.clear()# print(d)# copy 淺拷貝new_d = d.copy()print('copy出的新字典:%s' % new_d) # {’name’: ’admin’, ’age’: 12}new_d[’name’] = ’root’print(’修改之后的copy字典:%s’ % new_d) # 修改之后的copy字典:{’name’: ’root’, ’age’: 12}print('修改之后的原字典:%s' % d) # {’name’: ’admin’, ’age’: 12}# 總結: copy淺拷貝簡單數據結構時,創建了一個新的對象,修改新dict中的值,不會引起原有dict中值的變化print(’*’ * 50)d = {'person': {'name': 'admin', 'age': 12}, 'animal': {'name': 'gaodan', 'age': 3} }print(d) # {’person’: {’name’: ’admin’, ’age’: 12}, ’animal’: {’name’: ’gaodan’, ’age’: 3}}new_d = d.copy()new_d[’person’][’name’] = ’root’print(new_d) # {’person’: {’name’: ’root’, ’age’: 12}, ’animal’: {’name’: ’gaodan’, ’age’: 3}}print(d) # {’person’: {’name’: ’root’, ’age’: 12}, ’animal’: {’name’: ’gaodan’, ’age’: 3}}# 總結: 淺拷貝: copy淺拷貝復雜數據結構時,只是指向了這個復雜數據結構的引用,并沒有創建一個新的對象.所以修改new_d這個新dict的值時,原dict中的值也發生變化.如果是簡單數據結構,不存在這類情況,上面也有示例''' python中的深拷貝 需要 import copy copy.deepcopy()'''print(’--------------------deep copy------------------’)import copyd = {'person': {'name': 'admin', 'age': 12}, 'animal': {'name': 'gaodan', 'age': 3} }print(d)dd = copy.deepcopy(d)print(dd) # {’person’: {’name’: ’admin’, ’age’: 12}, ’animal’: {’name’: ’gaodan’, ’age’: 3}}dd[’person’][’name’] = ’啞巴’print(dd) # {’person’: {’name’: ’啞巴’, ’age’: 12}, ’animal’: {’name’: ’gaodan’, ’age’: 3}}print(d) # {’person’: {’name’: ’admin’, ’age’: 12}, ’animal’: {’name’: ’gaodan’, ’age’: 3}}# fromkeys, 創建一個新的dict ,key是序列中的值d = dict.fromkeys([’jet’,’lily’],{'name':'mam'})print(d) # {’jet’: {’name’: ’mam’}, ’lily’: {’name’: ’mam’}}# get .取值 ,沒有就是Nonevalue = d.get('jet')print(value) #{’name’: ’mam’}d = {'name':’admin’,’age’:12}#items 方法kv = d.items()for k,v in kv: print(k,v)keys = d.keys()print(keys) # dict_keys([’name’, ’age’])# pop(key) 移除指定的key 對應的kv# value = d.pop(’name’) # 刪除name 鍵值對# print(value) # admin# print(d) # {’age’: 12}# popitem 移除后面的一組itempopitem = d.popitem()print(popitem) # (’age’, 12) 移除了這一對映射關系print(d) # {’name’: ’admin’} d 還剩下這玩藝d = {'name':’admin’,’age’:12}# setdefault(k,v) , 如果原dict有中k, 就返回原dict中k-->v , 否則就將k,v添加到dict中default_value = d.setdefault(’female’, ’ali’)print(default_value)print(d) # {’name’: ’admin’, ’age’: 12, ’female’: ’ali’}default_value = d.setdefault(’female’, ’jd’)print(default_value) # aliprint(d) # {’name’: ’admin’, ’age’: 12, ’female’: ’ali’}# update. 往dict中添加元素# 使用update的第一種方式 ,注意key沒有加引號# d.update(book=’python’,teacher=’dog’)print(d) # {’name’: ’admin’, ’age’: 12, ’female’: ’ali’, ’book’: ’python’, ’teacher’: ’dog’}#使用update的第二種方式d.update([(’teacher’,’dog’),{’book’,’java’}]) #好吊的樣子print(d) #{’name’: ’admin’, ’age’: 12, ’female’: ’ali’, ’teacher’: ’dog’, ’book’: ’java’}# valuesvs = d.values()print(vs) #dict_values([’admin’, 12, ’ali’, ’dog’, ’java’])

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 溧水县| 呈贡县| 修武县| 邵阳市| 大荔县| 彭水| 怀集县| 蓝山县| 新田县| 敖汉旗| 龙川县| 合水县| 崇阳县| 阿鲁科尔沁旗| 廊坊市| 怀远县| 威远县| 台南县| 大宁县| 南昌县| 日照市| 志丹县| 通州区| 萨嘎县| 资源县| 静海县| 凤冈县| 芜湖县| 淳化县| 商丘市| 同江市| 巴南区| 敦煌市| 宁武县| 三穗县| 阜康市| 正蓝旗| 阿瓦提县| 镇安县| 东乡| 娄烦县|