草庐IT

python基础-字典常用操作

white-list 2023-04-19 原文

1.通过key获取value

  dict = {key1: value1, key2:value2}

  dict['key1'] 可获取到key1对应的value1  

person = {'name': 'tt', 'age': 13}
print(person['age'])  # 13

test_dict = {'name': 'll', 'age': 90}
print(test_dict['height'])  # 无value时程序报错,KeyError: 'height'

  通过dict[key] = value ,当key值存在是,会修改原value、当key值不存在时,会将key:value键值对添加到字典中;

person = {'name': 'tt', 'age': 13}
person['age'] = 24
print(person)  # {'name': 'tt', 'age': 24}
person['height'] = 178
print(person)  # {'name': 'tt', 'age': 24, 'height': 178}

 

2.字典的update()方法

  dict.update(new_dict) 一次添加多个键值对,同样key值存在时更新key对应的value、key值不存在是添加key:value对;

person = {'name': 'tt', 'age': 13}
person.update({'like': 'football', 'age': 134})
print(person)  # {'name': 'tt', 'age': 134, 'like': 'football'}

 

3.字典的setdefault()方法

  dict.setdefault(key, default_value)  

  key值存在时,直接返回对应的value;key值不存在时,将key: default_value键值对添加进字典;

  default_value值可省略,默认是None;

person = {'name': 'tt', 'age': 13}
print(person.setdefault('age', 45))  # 13
print(person.setdefault('like', 'football'))  # football
print(person)  # {'name': 'tt', 'age': 13, 'like': 'football'}
print(person.setdefault('height'))  # None
print(person)  # {'name': 'tt', 'age': 13, 'like': 'football', 'height': None}

 

4.获取字典全部值

  dict.keys()  获取字典中全部key值,返回一个伪列表;

  dict.values() 获取字典中全部value的值,返回一个伪列表;

  dict.items() 获取字典所有的键值对, 返回伪列表,各键值对存在列表内的元组中;

person = {'name': 'tt', 'age': 13}
print(person.keys())  # dict_keys(['name', 'age'])
print(list(person.keys()))  # ['name', 'age'] (可以转化成列表)

print(person.values())  # dict_values(['tt', 13])
print(list(person.values()))  # ['tt', 13]

print(person.items())  # dict_items([('name', 'tt'), ('age', 13)])
print(list(person.items()))  # [('name', 'tt'), ('age', 13)]

 

5.字典的get() 方法

  dict.get(key)  获取对应value,无key时、默认返回None;

  dict.get(key,  default_value)  无key时,可以指定返回结果default_value;

person = {'name': 'tt', 'age': 13}
print(person.get('age'))  # 13
print(person.get('like'))  # None
print(person.get('like', 'no key'))  # no key

print(person['like'])  # 程序报错,KeyError: 'like'
# person['like']方式比get()方式可以节省部分时间,不用做key是否存在的判断(但基本可忽略不计)
# get()方式比person['like']方式,在返回结果上更友善些

 

6.字典的删除操作

  dict.pop(key)  删除key:value对,并返回value值;key不存在时会报错;

  dict.clear()  清空字典;

  dict.popitem()  删除字典的最后一个键值对, 返回键值对存储在元组中;

  同样可借助python内置函数del;

person = {'name': 'tt', 'age': 13, 'like': 'football', 'height': 168}
print(person.pop('name'))  # tt (操作有返回值,值是value)
print(person)  # {'age': 13, 'like': 'football', 'height': 168}

print(person.popitem())  # ('height', 168)
print(person)  # {'age': 13, 'like': 'football'}

del person['like']
print(person)  # {'age': 13}
# del person['name']  # KeyError: 'name' (无对应key时,会报错)

person.clear()
print(person)  # {}

 

7.字典的copy()函数

  复制字典内元素生成新字典;

# dict.copy() 依旧属于浅拷贝
person = {
    'xiaoming': {
        'age': 23,
        'height': 178
    },
    'xiaohong': {
        'age': 26,
        'height': 168
    }
}
new_person = person.copy()
new_person['xiaoming']['age'] = 999
print(new_person)  # {'xiaoming': {'age': 999, 'height': 178}, 'xiaohong': {'age': 26, 'height': 168}}
print(person)  # {'xiaoming': {'age': 999, 'height': 178}, 'xiaohong': {'age': 26, 'height': 168}}
# import copy, copy.deepcopy() 可完成深拷贝操作
import copy
person = {
    'xiaoming': {
        'age': 23,
        'height': 178
    },
    'xiaohong': {
        'age': 26,
        'height': 168
    }
}
new_person = copy.deepcopy(person)
new_person['xiaoming']['age'] = 999
print(new_person)  # {'xiaoming': {'age': 999, 'height': 178}, 'xiaohong': {'age': 26, 'height': 168}}
print(person)  # {'xiaoming': {'age': 23, 'height': 178}, 'xiaohong': {'age': 26, 'height': 168}}


# value值也可以是列表,情况一样
# 浅拷贝
dict_test = {'name': ['ll', 'rr', 'yy'], 'age': [34, 56]}
new_dict = dict_test.copy()
new_dict['name'][0] = 'pppp'
print(new_dict)  # {'name': ['pppp', 'rr', 'yy'], 'age': [34, 56]}
print(dict_test)  # {'name': ['pppp', 'rr', 'yy'], 'age': [34, 56]}

# 深拷贝
import copy
dict_test2 = {'name': ['ll', 'rr', 'yy'], 'age': [34, 56]}
new_dict2 = copy.deepcopy(dict_test2)
new_dict2['name'][0] = 'pppp'
print(new_dict2)  # {'name': ['pppp', 'rr', 'yy'], 'age': [34, 56]}
print(dict_test2)  # {'name': ['ll', 'rr', 'yy'], 'age': [34, 56]}

 

8.其它简单操作

  in ,not in 成员判断;

  len(dict) 判断字典长度;

test_dict = {'name': 'll', 'age': 90}
print('name' in test_dict)  # True
print(len(test_dict))  # 2

# 字典没有累加累乘操作

  

总结

    

有关python基础-字典常用操作的更多相关文章

  1. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  2. ruby-on-rails - Rails 常用字符串(用于通知和错误信息等) - 2

    大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje

  3. Python 相当于 Perl/Ruby ||= - 2

    这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Pythonconditionalassignmentoperator对于这样一个简单的问题表示歉意,但是谷歌搜索||=并不是很有帮助;)Python中是否有与Ruby和Perl中的||=语句等效的语句?例如:foo="hey"foo||="what"#assignfooifit'sundefined#fooisstill"hey"bar||="yeah"#baris"yeah"另外,类似这样的东西的通用术语是什么?条件分配是我的第一个猜测,但Wikipediapage跟我想的不太一样。

  4. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

    什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

  5. 华为OD机试用Python实现 -【明明的随机数】 2023Q1A - 2

    华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o

  6. python - 如何读取 MIDI 文件、更改其乐器并将其写回? - 2

    我想解析一个已经存在的.mid文件,改变它的乐器,例如从“acousticgrandpiano”到“violin”,然后将它保存回去或作为另一个.mid文件。根据我在文档中看到的内容,该乐器通过program_change或patch_change指令进行了更改,但我找不到任何在已经存在的MIDI文件中执行此操作的库.他们似乎都只支持从头开始创建的MIDI文件。 最佳答案 MIDIpackage会为您完成此操作,但具体方法取决于midi文件的原始内容。一个MIDI文件由一个或多个音轨组成,每个音轨是十六个channel中任何一个上的

  7. 「Python|Selenium|场景案例」如何定位iframe中的元素? - 2

    本文主要介绍在使用Selenium进行自动化测试或者任务时,对于使用了iframe的页面,如何定位iframe中的元素文章目录场景描述解决方案具体代码场景描述当我们在使用Selenium进行自动化测试的时候,可能会遇到一些界面或者窗体是使用HTML的iframe标签进行承载的。对于iframe中的标签,如果直接查找是无法找到的,会抛出没有找到元素的异常。比如近在咫尺的例子就是,CSDN的登录窗体就是使用的iframe,大家可以尝试通过F12开发者模式查看到的tag_name,class_name,id或者xpath来定位中的页面元素,会抛出NoSuchElementException异常。解决

  8. postman接口测试工具-基础使用教程 - 2

    1.postman介绍Postman一款非常流行的API调试工具。其实,开发人员用的更多。因为测试人员做接口测试会有更多选择,例如Jmeter、soapUI等。不过,对于开发过程中去调试接口,Postman确实足够的简单方便,而且功能强大。2.下载安装官网地址:https://www.postman.com/下载完成后双击安装吧,安装过程极其简单,无需任何操作3.使用教程这里以百度为例,工具使用简单,填写URL地址即可发送请求,在下方查看响应结果和响应状态码常用方法都有支持请求方法:getpostputdeleteGet、Post、Put与Delete的作用get:请求方法一般是用于数据查询,

  9. 软件测试基础 - 2

    Ⅰ软件测试基础一、软件测试基础理论1、软件测试的必要性所有的产品或者服务上线都需要测试2、测试的发展过程3、什么是软件测试找bug,发现缺陷4、测试的定义使用人工或自动的手段来运行或者测试某个系统的过程。目的在于检测它是否满足规定的需求。弄清预期结果和实际结果的差别。5、测试的目的以最小的人力、物力和时间找出软件中潜在的错误和缺陷6、测试的原则28原则:20%的主要功能要重点测(eg:支付宝的支付功能,其他功能都是次要的)80%的错误存在于20%的代码中7、测试标准8、测试的基本要求功能测试性能测试安全性测试兼容性测试易用性测试外观界面测试可靠性测试二、质量模型衡量一个优秀软件的维度①功能性功

  10. 微信小程序通过字典表匹配对应数据 - 2

    前言一般来说,前端根据后台返回code码展示对应内容只需要在前台判断code值展示对应的内容即可,但要是匹配的code码比较多或者多个页面用到时,为了便于后期维护,后台就会使用字典表让前端匹配,下面我将在微信小程序中通过wxs的方法实现这个操作。为什么要使用wxs?{{method(a,b)}}可以看到,上述代码是一个调用方法传值的操作,在vue中很常见,多用于数据之间的转换,但由于微信小程序诸多限制的原因,你并不能优雅的这样操作,可能有人会说,为什么不用if判断实现呢?但是if判断的局限性在于如果存在数据量过大时,大量重复性操作和if判断会让你的代码显得异常冗余。wxswxs相当于是一个独立

随机推荐