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之字典二 内置方法总结的更多相关文章

  1. Python 数据类型常用的内置方法(二)

    目录 Python 数据类型常用的内置方法(二) 1.字符串类型常用内置方法 1.upper.lower.isupper.islower 2.startswith.endswith 3.format ...

  2. what's the python之基本运算符及字符串、列表、元祖、集合、字典的内置方法

    计算机可以进行的运算有很多种,运算按种类可分为算数运算.比较运算.逻辑运算.赋值运算.成员运算.身份运算.字符串和列表的算数运算只能用+和*,字典没有顺序,所以不能进行算数运算和比较运算.比较运算中= ...

  3. python面向对象 : 反射和内置方法

    一. 反射 1. isinstance()和issubclass() isinstance( 对象名, 类名) : 判断对象所属关系,包括父类  (注:type(对象名) is 类名 : 判断对象所属 ...

  4. Python 数据类型常用的内置方法(三)

    目录 Python 数据类型常用的内置方法(三) 1.列表内置方法 1.sort():升序 2.reverse():颠倒顺序 3.列表比较运算 2.字典内置方法 1.对Key的操作 2.len( )- ...

  5. python之数据类型的内置方法(set、tuple、dict)与简单认识垃圾回收机制

    目录 字典的内置方法 类型转换 字典取值 修改值 计算字典长度 成员运算 删除元素 获取元素 更新字典 快速生成字典 setdefault()方法 元组的内置方法 类型转换 索引与切片操作 统计长度 ...

  6. Python 数据类型常用的内置方法(一)

    目录 Python 数据类型常用的内置方法 1.整型 int 2.浮点型 float 字符串转浮点型: 3.字符串 str 多种类型转字符型: 索引 切片 len( )方法:统计字符串长度/个数 移除 ...

  7. python基础之反射内置方法元类

    补充内置函数 isinstance(obj,Foo)   # 判断obj是不是foo的实例 issubclass()      # 判断一个类是不是另一个类的子类 反射 什么是反射? 通过字符串来操作 ...

  8. 《Python》反射、内置方法(__str__,__repr__)

    一.反射 通过字符串的形式操作对象相关的属性.(使用字符串数据类型的变量名来获取这个变量的值) Python中的一切事物都是对象(都可以使用反射) 反射类中的变量 反射对象中的变量 反射模板中的变量 ...

  9. 元组/字典/集合内置方法+简单哈希表(day07整理)

    目录 二十三.元组内置方法 二十四.字典数据类型 二十五 集合内置方法 二十五.数据类型总结 二十六.深浅拷贝 补充:散列表(哈希表) 二十三.元组内置方法 什么是元组:只可取,不可更改的列表 作用: ...

随机推荐

  1. Qt编写数据可视化大屏界面电子看板1-布局方案

    一.前言 布局方案在整个数据可视化大屏界面电子看板系统中,是除了基础功能以外的核心功能之一,只有具备了布局方案这个功能,才能让用户随意调整自己想要的布局,保存成自定义名称的布局配置文件,这样就大大增加 ...

  2. Linux 上svn使用http访问设置

    https://blog.csdn.net/wobuxingfang/article/details/70835414https://blog.csdn.net/u010487568/article/ ...

  3. python中学习K-Means和图片压缩

    python中学习K-Means和图片压缩 大家在学习python中,经常会使用到K-Means和图片压缩的,我们在此给大家分享一下K-Means和图片压缩的方法和原理,喜欢的朋友收藏一下吧. 通俗的 ...

  4. python基础知识(字典)

    创建字典 变量名 = {key:value,.....} zip()    转换为zip对象 空字典 变量名 = {} 变量名 = dict(key = value,....) 创建只有键的字典 fr ...

  5. iscsi-文件类型

    iSCSI简介(Internet SCSI): iSCSI 小型计算机系统接口,IBM公司研发,用于在IP网络上运行SCSI协议:解决了 SCSI需要直连存储设备的局限性:可以不停机扩展存储容量,iS ...

  6. ipmitool管理工具

    一.ipmitool简介 IPMI(Intelligent Platform Management Interface)智能平台管理接口 1.IPMI的核心是一个专用芯片/控制器(叫做服务器处理器或基 ...

  7. CSRF类型

    按照请求类型来区分.分为:GET类型和POST类型 按照攻击类型分类,CSRF可分为:HTML CSRF攻击,JSOM HiJacking攻击和FIash CSRF攻击 HTML CSRF攻击 HTM ...

  8. 请求头出现Provisional headers are shown

    provisional headers are shown 知多少:https://juejin.im/post/5c00980751882518805add83 请求头出现Provisional h ...

  9. jenkins 控制台输出中文乱码

    jenkins在执行构建任务时会在 console output 进行任务的日志输出,但中文输出会乱码,如下图 解决办法: Manage Jenkins --->  系统配置 ---> 全 ...

  10. GIT SSH-KEY配置以及问题解决

    GIT SSH-KEY 生成 我们在使用git的时候需要生成ssh key,我在这里说一下生成key和一些个性化操作,如:保存key的位置,如何解决Could not open a connectio ...