python之字典二 内置方法总结
Python字典包含了以下内置方法:
clear()函数用于删除字典内所有元素
dict1 = {'Name': 'Zara', 'Age': , 'Class': 'First'}
print('the start len %d' % len(dict1))
dict1.clear()
print('the end len %d' % len(dict1))
结果:
[python@master tmp]$ python3 c.py
the start len
the end len
copy() 函数返回一个字典的浅复制
例子1:
dict1 = {'Name': 'Zara', 'Age': , 'Class': 'First'}
dict2=dict1.copy()
print('New Dictinary : %s' % str(dict2))
结果:
[python@master tmp]$ python3 d.py
New Dictinary : {'Name': 'Zara', 'Age': , 'Class': 'First'} 例子2:
dict1 = {'user':'runoob','num':[,,]}
dict2 = dict1 # 浅拷贝: 引用对象
dict3 = dict1.copy() # 浅拷贝:深拷贝父对象(一级目录),子对象(二级目录)不拷贝,还是引用 dict1['user']='root'
dict1['num'].remove() print(dict1)
print(dict2)
print(dict3)
结果
[python@master tmp]$ python3 d.py
{'user': 'root', 'num': [, ]}
{'user': 'root', 'num': [, ]}
{'user': 'runoob', 'num': [, ]}
实例中 dict2 其实是 dict1 的引用(别名),所以输出结果都是一致的,dict3 父对象进行了深拷贝,不会随dict1 修改而修改,子对象是浅拷贝所以随 dict1 的修改而修改。
fromkeys() 函数用于创建一个新字典,以序列 seq 中元素做字典的键,value 为字典所有键对应的初始值。
dict.fromkeys(seq[, value]) seq -- 字典键值列表。 value -- 可选参数, 设置键序列(seq)的值。
seq =('Google', 'Runoob', 'Taobao')
dict = dict.fromkeys(seq)
print ("新字典为 : %s" % str(dict))
dict = dict.fromkeys(seq, )
print ("新字典为 : %s" % str(dict))
结果:
[python@master tmp]$ python3 f.py
新字典为 : {'Google': None, 'Runoob': None, 'Taobao': None}
新字典为 : {'Google': , 'Runoob': , 'Taobao': }
get() 函数返回指定键的值,如果值不在字典中返回默认值(None)
dict = {'Name': 'Zara', 'Age': , 'Class': 'First'}
print('Name: %s' % dict.get('Name'))
print('adress1: %s' % dict.get('adress','henan'))
print('adress2: %s' % dict.get('adress'))
结果:
[python@master tmp]$ python3 a.py
Name: Zara
adress1: henan
adress2: None
has_key() 函数用于判断键是否存在于字典中,如果键在字典dict里返回true,否则返回false
python3 中放弃了这个函数,用变量in来代替
dict = {'Name': 'Zara', 'Age': , 'Class': 'First'}
dict_keys=input('please input dict key: ')
if dict_keys in dict:
print(dict_keys +': %s'% dict[dict_keys])
else:
print(dict_keys +' not in dict')
结果:
[python@master tmp]$ python3 b.py
please input dict key: Name
Name: Zara
items() 函数以列表返回可遍历的(键, 值) 元组数组
dict = {'Name': 'Zara', 'Age': , 'Class': 'First'}
dict_keys=input('please input dict key: ')
if dict_keys in dict:
print(dict_keys +': %s'% dict[dict_keys])
else:
print(dict_keys +' not in dict')
结果:
[python@master tmp]$ python3 c.py
字典值 : dict_items([('Name', 'Zara'), ('Age', ), ('Class', 'First')])
Name:Zara
Age:
Class:First
keys() 函数以列表返回一个字典所有的键
dict = {'Name': 'Zara', 'Age': , 'Class': 'First'}
print("dict's keys :%s" % dict.keys())
结果:
[python@master tmp]$ python3 d.py
dict's keys :dict_keys(['Name', 'Age', 'Class'])
setdefault() 函数和get()类似, 如果键不存在于字典中,将会添加键并将值设为默认值
dict = {'Name': 'Zara', 'Age': , 'Class': 'First'}
print("dict's keys :%s" % dict.setdefault('Name',None))
print(dict)
print("dict's keys :%s" % dict.setdefault('Adress','henan'))
print(dict)
结果:
[python@master tmp]$ python3 f.py
dict's keys :Zara
{'Name': 'Zara', 'Age': , 'Class': 'First'}
dict's keys :henan
{'Name': 'Zara', 'Age': , 'Class': 'First', 'Adress': 'henan'}
update() 函数把字典dict2的键/值对更新到dict里
dict1 = {'Name': 'Zara', 'Age': , 'Class': 'First'}
print(dict1)
print('updated end')
dict2 = {'Adress': 'henan'}
dict1.update(dict2)
print(dict1)
结果:
[python@master tmp]$ python3 g.py
{'Name': 'Zara', 'Age': , 'Class': 'First'}
updated end
{'Name': 'Zara', 'Age': , 'Class': 'First', 'Adress': 'henan'}
values() 函数以列表返回字典中的所有值
dict1 = {'Name': 'Zara', 'Age': , 'Class': 'First'}
print("dict1's values : %s" % dict1.values())
结果:
[python@master tmp]$ python3 m.py
dict1's values : dict_values(['Zara', 7, 'First'])
pop() 方法删除字典给定键 key 所对应的值,返回值为被删除的值。key值必须给出。 否则,返回default值
dict1 = {'Name': 'Zara', 'Age': , 'Class': 'First'}
dict2=dict1.pop('Name')
print('dict1 :%s' % dict1)
print('dict2 :%s' % dict2)
结果:
[python@master tmp]$ python3 .py
dict1 :{'Age': , 'Class': 'First'}
dict2 :Zara
popitem() 方法随机返回并删除字典中的一对键和值,如果字典已经为空,却调用了此方法,就报出KeyError异常。
dict1 = {'Name': 'Zara', 'Age': , 'Class': 'First'}
dict2=dict1.popitem()
print('dict1 :%s' % dict1)
print('dict2 :%s' % str(dict2))
结果:
[python@master tmp]$ python3 .py
dict1 :{'Name': 'Zara', 'Age': }
dict2 :('Class', 'First')
我们所处的世道,总是这般复杂,走着走着,杂草丛生,荒庙破寺。走着走着,杨柳依依,桃花烂漫。走着走着,穷山恶水,夜幕深沉。走着走着,琼楼玉宇,大放光明。
——剑来《人间苦难说不得也》
python之字典二 内置方法总结的更多相关文章
- Python 数据类型常用的内置方法(二)
目录 Python 数据类型常用的内置方法(二) 1.字符串类型常用内置方法 1.upper.lower.isupper.islower 2.startswith.endswith 3.format ...
- what's the python之基本运算符及字符串、列表、元祖、集合、字典的内置方法
计算机可以进行的运算有很多种,运算按种类可分为算数运算.比较运算.逻辑运算.赋值运算.成员运算.身份运算.字符串和列表的算数运算只能用+和*,字典没有顺序,所以不能进行算数运算和比较运算.比较运算中= ...
- python面向对象 : 反射和内置方法
一. 反射 1. isinstance()和issubclass() isinstance( 对象名, 类名) : 判断对象所属关系,包括父类 (注:type(对象名) is 类名 : 判断对象所属 ...
- Python 数据类型常用的内置方法(三)
目录 Python 数据类型常用的内置方法(三) 1.列表内置方法 1.sort():升序 2.reverse():颠倒顺序 3.列表比较运算 2.字典内置方法 1.对Key的操作 2.len( )- ...
- python之数据类型的内置方法(set、tuple、dict)与简单认识垃圾回收机制
目录 字典的内置方法 类型转换 字典取值 修改值 计算字典长度 成员运算 删除元素 获取元素 更新字典 快速生成字典 setdefault()方法 元组的内置方法 类型转换 索引与切片操作 统计长度 ...
- Python 数据类型常用的内置方法(一)
目录 Python 数据类型常用的内置方法 1.整型 int 2.浮点型 float 字符串转浮点型: 3.字符串 str 多种类型转字符型: 索引 切片 len( )方法:统计字符串长度/个数 移除 ...
- python基础之反射内置方法元类
补充内置函数 isinstance(obj,Foo) # 判断obj是不是foo的实例 issubclass() # 判断一个类是不是另一个类的子类 反射 什么是反射? 通过字符串来操作 ...
- 《Python》反射、内置方法(__str__,__repr__)
一.反射 通过字符串的形式操作对象相关的属性.(使用字符串数据类型的变量名来获取这个变量的值) Python中的一切事物都是对象(都可以使用反射) 反射类中的变量 反射对象中的变量 反射模板中的变量 ...
- 元组/字典/集合内置方法+简单哈希表(day07整理)
目录 二十三.元组内置方法 二十四.字典数据类型 二十五 集合内置方法 二十五.数据类型总结 二十六.深浅拷贝 补充:散列表(哈希表) 二十三.元组内置方法 什么是元组:只可取,不可更改的列表 作用: ...
随机推荐
- File Zilla连接Ubuntu 失败
一.SFTP方式连接失败 站点配置 连接失败 二.FTP连接方式失败 站点配置 连接失败
- Kafka管理与监控——查看和重设消费者组位移
kafka 0.11.0.0版本丰富了kafka-consumer-groups脚本的功能,用户可以直接使用该脚本很方便地为已有的consumer group重新设置位移. 前提必须consumer ...
- new URLSearchParams( )用法说明
URLSearchParams 接口定义了一些实用的方法来处理 URL 的查询字符串. 方法:该接口不继承任何属性. URLSearchParams.append() 插入一个指定的键/值对作为新的搜 ...
- 关于Java新手开发配置各种环境可能会遇到的的坑
一.软件的安装 虽然国内的软件都支持中文目录安装,部分国外软件也支持,但是作为一名合格的程序开发者,必须做到以下几点 Windows下开发软件的安装目录和环境变量中永远不要包含中文字符,包括汉字[]. ...
- Leetcode之动态规划(DP)专题-746. 使用最小花费爬楼梯(Min Cost Climbing Stairs)
Leetcode之动态规划(DP)专题-746. 使用最小花费爬楼梯(Min Cost Climbing Stairs) 数组的每个索引做为一个阶梯,第 i个阶梯对应着一个非负数的体力花费值 cost ...
- 前端CSS实现图片自适应背景大小
<body> <div> <!--背景图片--> <div id="web_bg" style="background-imag ...
- Kafka如何保证百万级写入速度以及保证不丢失不重复消费
一.如何保证百万级写入速度: 目录 1.页缓存技术 + 磁盘顺序写 2.零拷贝技术 3.最后的总结 “这篇文章来聊一下Kafka的一些架构设计原理,这也是互联网公司面试时非常高频的技术考点. Kafk ...
- MFC控件使用大全
https://blog.csdn.net/daoming1112/article/details/54698113
- linux常用终端命令(一)终端命令格式(二)文件和目录常用命令
一.linux终端命令格式 1.终端命令格式 command [-options] [parameter] 说明: command :命令名,相应功能的英文单词或单词的缩写 [-options] ...
- 关于python中的包,模块导入的问题详解(二)
from import导入 紧接着的是from xx import xx 语法 1 ################ 2 from my_moudule import name 3 print(na ...