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. Scala安装配置和使用

  2. openstack核心组件--cinder存储服务(6)

    一.cinder 介绍:   理解 Block Storage 操作系统获得存储空间的方式一般有两种: 通过某种协议(SAS,SCSI,SAN,iSCSI 等)挂接裸硬盘,然后分区.格式化.创建文件系 ...

  3. Centos7.4 下cobbler安装及配置

    1.背景介绍 作为运维,在公司经常遇到一些机械性重复工作要做,例如:为新机器装系统,一台两台机器装系统,可以用光盘.U盘等介质安装,1小时也完成了,但是如果有成百台的服务器还要用光盘.U盘去安装,就显 ...

  4. Java泛型(8):自限定&参数协变

    自限定 自限定将强制泛型当做自己的边界参数来使用.自限定所做的,就是要求在继承关系中,像下面这样使用这个类: class A extends SelfBounded<A> {} 它的意义是 ...

  5. DRF之APIView源码解析

    目录 Django项目中的代码如下 APIView源码解析 源码解析总结 Django项目中的代码如下 urls.py中: from django.conf.urls import url from ...

  6. 二、windows下搭建vue开发环境+IIS部署

    有时我们的服务器并不一定是node,也许是IIS,这样我们就需要把工程构建出来,与IIS集成. 构建该项目的命令如下 cnpm run build 将dist文件夹拷贝出来,放到IIS的发布目录,在浏 ...

  7. vue定义global.js,挂载在vue原型上面使用

    首先在src目录下创建global目录,在global目录下创建index.js. export default { install(Vue) { var that = this // 1. 添加全局 ...

  8. spring-cloud-starter-stream-rocketmq 坑点j记录

  9. springboot整合es客户端操作elasticsearch(四)

    对文档查询,在实际开发中,对文档的查询也是偏多的,记得之前在mou快递公司,做了一套事实的揽件数据操作,就是通过这个来存储数据的,由于一天的数据最少拥有3500万数据 所以是比较多的,而且还要求查询速 ...

  10. Origin

    1.简单的使用 http://wenku.baidu.com/link?url=K1ThI9a-Ws_Rk28K28kBEc9uNRN7k4vHV4pxfieMCaLeA4rGotRAnk8fxCUm ...