zl程序教程

您现在的位置是:首页 >  Python

当前栏目

Python基础--字典

2023-02-18 16:38:17 时间

什么是字典

字典是另一种可变容器模型,且可存储任意类型对象。

字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中 ,格式如下所示:

d = {key1 : value1, key2 : value2 }
键必须是唯一的,但值则不必。

值可以取任何数据类型,但键必须是不可变的,如字符串,数字或元组,如果出现相同的键则前面键的值会被后面键的值所覆盖

dict = {'姓名': 'chenshifeng', '爱好': ('Python','java'), 'city': '杭州','number':666}
如何访问字典里的值

通过key访问value,也可以直接打印出所有的key—value

dict1 = {"name": "cc", "age": 18}  # 直接创建
print("字典dict1为 : %s" % dict1)

dict2 = dict(name="cc", age="18")  # 通过dict方法创建,不常用
print("字典dict2为 : %s" % dict2)

seq = ('name', 'age', 'sex')
dict3 = dict.fromkeys(seq)  # 创建一个新字典,以序列seq中元素做字典的键,value为字典所有键对应的初始值
print("字典dict3为 : %s" % str(dict3))
dict4 = dict.fromkeys(seq, 10)
print("字典dict4为 : %s" % str(dict4))

结果为:

字典dict1为 : {'name': 'cc', 'age': 18}
字典dict2为 : {'name': 'cc', 'age': '18'}
字典dict3为 : {'name': None, 'age': None, 'sex': None}
字典dict4为 : {'name': 10, 'age': 10, 'sex': 10}

能删单一的元素也能清空字典

dict = {'姓名': 'chenshifeng', '爱好': ('Python', 'java'), 'city': '杭州', 'number': 666}
del dict['city']  # 删除键 'city'
print(dict)
dict.clear()  # 清空字典数据
print(dict)
del dict  # 删除字典
print(dict)
dict1 = {'姓名': 'chenshifeng', '爱好': ('Python', 'java'), 'city': '杭州', 'number': 666}
dict1.pop("number")  # 删除键 'number'
print(dict1)
dict1.popitem()  # 随机返回并删除字典中的一对键和值(一般删除末尾对)
print(dict1)

结果为

{'姓名': 'chenshifeng', '爱好': ('Python', 'java'), 'number': 666}
{}
<class 'dict'>
{'姓名': 'chenshifeng', '爱好': ('Python', 'java'), 'city': '杭州'}
{'姓名': 'chenshifeng', '爱好': ('Python', 'java')}

向字典添加新内容的方法是增加新的键/值对,修改或删除已有键/值对,此方法简单粗暴,如下实例:

dict = {'姓名': 'chenshifeng', '爱好': ('Python', 'java'), 'city': '杭州', 'number': 666}
dict['number'] = 888  # 更新 Age   无则添加,有则更新 Age
print(dict)
dict['age'] = 18  # 添加信息
print(dict)
dict.update({"love": "ww"})  # 无则添加,有则更新 Age
print(dict)

结果为

{'姓名': 'chenshifeng', '爱好': ('Python', 'java'), 'city': '杭州', 'number': 888}
{'姓名': 'chenshifeng', '爱好': ('Python', 'java'), 'city': '杭州', 'number': 888, 'age': 18}
{'姓名': 'chenshifeng', '爱好': ('Python', 'java'), 'city': '杭州', 'number': 888, 'age': 18, 'love': 'ww'}

dict1 = {'name': 'chenshifeng', 'age': 18}

print(dict1)  # 直接查询整个字段
print(dict1['name'])  # 根据KEY查询VALUE,key会报错
print("age 值为 : %s" % dict1.get('age'))  # 返回指定键的值如果值不在字典中返回default值
print("sex 值为 : %s" % dict1.get('sex', "NA"))
print("sex 值为 : %s" % dict1.get('sex'))
print("新字典为:", dict1)
print("----------------------------------------------")
print("age 键的值为 : %s" % dict1.setdefault('age', "1"))
print("sex 键的值为 : %s" % dict1.setdefault('sex', "男"))  # 和get()类似, 但如果键不存在于字典中,将会添加键并将值设为default
print("新字典为:", dict1)

结果为

{'name': 'chenshifeng', 'age': 18}
chenshifeng
age 值为 : 18
sex 值为 : NA
sex 值为 : None
新字典为: {'name': 'chenshifeng', 'age': 18}
----------------------------------------------
age 键的值为 : 18
sex 键的值为 : 男
新字典为: {'name': 'chenshifeng', 'age': 18, 'sex': '男'}

字典键的特性

1)不允许同一个键出现两次。创建时如果同一个键被赋值两次,后一个值会被记住

dict = {'姓名': 'chenshifeng', '爱好': ('Python', 'java'), 'city': '杭州', 'number': 666,'姓名': '尘世风'}
print(dict)

结果为:

{'姓名': '尘世风', '爱好': ('Python', 'java'), 'city': '杭州', 'number': 666}

2)键必须不可变,所以可以用数字,字符串或元组充当,而用列表就不行

dict = {('name','englishname'):['尘世风','chenshifeng']}
print(dict)
dict1 = {['name','englishname']:['尘世风','chenshifeng']}
print(dict1)

第一个正确,第二个会报错,结果如下

Traceback (most recent call last):
{('name', 'englishname'): ['尘世风', 'chenshifeng']}
  File "E:/Pythoncode/PythonAutomation/day2/test1.py", line 39, in <module>
    dict1 = {['name','englishname']:['尘世风','chenshifeng']}
TypeError: unhashable type: 'list'

字典其他内置函数&方法

Python字典包含了以下内置函数:

1)len(dict) :计算字典元素个数,即键的总数。
image
2)str(dict) :输出字典,以可打印的字符串表示。
image
3)type(variable) :返回输入的变量类型,如果变量是字典就返回字典类型。
image

4)dict.copy() :返回一个字典的浅复制
所谓浅拷贝是指:深拷贝父对象(一级目录),子对象(二级目录)不拷贝,还是引用

import copy   #copy 里面的copy就是浅拷贝,deepcopy才是深拷贝

dict1 = {'姓名': '尘世风', '爱好': ['Python','java','C++'], 'city': '杭州','number':666}
dict2 = dict1          # 浅拷贝: 引用对象
dict3 = dict1.copy()   # 浅拷贝:深拷贝父对象(一级目录),子对象(二级目录)不拷贝,还是引用,即第一层数据独立,第二层数据不独立
dict4 = copy.deepcopy(dict1)  #深拷贝
# 修改数据
dict1['姓名'] = 'chenshifeng'
dict1['爱好'].remove('C++')
# 输出结果
print(dict1)
print(dict2)
print(dict3)
print(dict4)

实例中 dict2 其实是 dict1 的引用(别名),所以输出结果都是一致的,dict3 父对象进行了深拷贝,不会随dict1 修改而修改,子对象是浅拷贝所以随 dict1 的修改而修改

{'姓名': 'chenshifeng', '爱好': ['Python', 'java'], 'city': '杭州', 'number': 666}
{'姓名': 'chenshifeng', '爱好': ['Python', 'java'], 'city': '杭州', 'number': 666}
{'姓名': '尘世风', '爱好': ['Python', 'java'], 'city': '杭州', 'number': 666}
{'姓名': '尘世风', '爱好': ['Python', 'java', 'C++'], 'city': '杭州', 'number': 666}

为什么有浅copy与深copy,一般不用深copy,要用也是用浅copy,应用场景:比如银行里面的共同账户,比较常用到浅copy

5)key in dict :如果键在字典dict里返回true,否则返回false

dict = {'name': 'chenshifeng', 'age': 18}

# 检测键 Age 是否存在
if  'age' in dict:
    print("键 age 存在")
else :
    print("键 age 不存在")

# 检测键 Sex 是否存在
if  'sex' in dict:
    print("键 sex 存在")
else :
    print("键 sex 不存在")

以上实例输出结果为:

键 age 存在
键 sex 不存在

6)dict.items() :以列表返回可遍历的(键, 值) 元组数组

dict = {'name': 'chenshifeng', 'age': 18}

print(dict.items())

以上实例输出结果为:

dict_items([('name', 'chenshifeng'), ('age', 18)])

7)dict.keys() :以列表返回一个字典所有的键

dict = {'name': 'chenshifeng', 'age': 18}

print(dict.keys())

以上实例输出结果为:

dict_keys(['name', 'age'])

for循环字典的时候,循环是他的key,若想循环key和value,可以用下面方式

users = {"name":"chenshifeng","age":18}
print(users.items())
for k,v in users.items(): #同时循环k和value
    print("%s=%s"%(k,v))

以上实例输出结果为:

dict_items([('name', 'chenshifeng'), ('age', 18)])
name=chenshifeng
age=18

这种是转化成list和元祖的方式取值,效率不高,下面这种方式效率较高

users = {"name":"chenshifeng","age":18}
for k in users:
    print("%s=%s"%(k,users[k]))

用in来判断一个值是不是字典里面的话,是判断字典key

users =  {
    "zyl":"123456",
    "jmt":"789123",
    "wjx":"cc"
}
if 'chenshifeng' in users:
    print('ok')
else:
    print('bu ok')

以上实例输出结果为:

bu ok

eval可以把字符串转成字典

user_info={
    "chenshifeng":{
        "money":100,
        "shengao":1.8,
        "password":"123456"
    },
    "agr":{
        "money":250,
        "shengao":1.5,
        "password":"123456"
    }
}
user_info2 = str(user_info)
print(type(user_info2))
new_user_info= eval(str(user_info))#把字符串转成字典
print(new_user_info)
print(type(new_user_info))

以上实例输出结果为:

<class 'str'>
{'chenshifeng': {'money': 100, 'shengao': 1.8, 'password': '123456'}, 'agr': {'money': 250, 'shengao': 1.5, 'password': '123456'}}
<class 'dict'>