列表尽管好,然而如果须要疾速的数据查找,就必须进行须要遍历,也就是最坏状况须要遍历完一遍能力找到须要的那个数据,工夫复杂度是O(n),显然这个速度是很难承受的,于是就必须要有新的数据结构呈现,于是字典就诞生了!

在Python中,字典(Dictionary)是一种无序的数据结构,用于存储键值对(key-value)。字典中的每个元素由一个键(key)和一个对应的值(value)组成,键和值之间应用冒号(:)进行分隔,每个键值对之间应用逗号(,)进行分隔。字典中的键必须是惟一的,而值能够是任意类型的对象。有点相似C++语言中的映射,工夫复杂度是O(1)。

Python中的字典次要有以下一些特点:

  • 无序性:字典中的元素没有固定的程序,不能通过索引来拜访元素。
  • 可变性:能够向字典中增加、批改或删除元素。
  • 惟一键:字典中的键必须是惟一的,如果增加了雷同的键,则前面的键值对会笼罩后面的键值对。

创立字典

很显然,应用字典之前须要先创立。在Python中,能够应用花括号 {} 或者 dict() 函数来创立字典。字典由键值对组成,每个键值对之间应用逗号 , 分隔。键和值之间应用冒号 : 分隔。以下是几种创立字典的形式示例:

1、应用花括号 {} 创立字典:

# 创立一个空字典my_dict = {}# 创立一个蕴含键值对的字典my_dict = {'key1': 'value1', 'key2': 'value2', 'key3': 'value3'}

2、应用 dict() 函数创立字典:

# 创立一个空字典my_dict = dict()# 创立一个蕴含键值对的字典my_dict = dict(key1='value1', key2='value2', key3='value3')# 应用列表或元组创立字典my_dict = dict([('key1', 'value1'), ('key2', 'value2'), ('key3', 'value3')])

3、应用字典推导式创立字典:

# 创立一个蕴含键值对的字典my_dict = {key: value for key, value in [('key1', 'value1'), ('key2', 'value2'), ('key3', 'value3')]}print(my_dict)

下面的第三种写法可能不少同学不容易了解,大家能够先记住就行,前面的教程咱们会讲到。

拜访字典

创立字典,咱们必定须要进行拜访,不然创立的就没什么意义了。在Python中,能够通过键来拜访字典中的值。以下是几种常见的拜访字典的形式:

1、利用方括号和键的形式,能够间接拜访字典中对应键的值。

person = {"name": "John", "age": 25, "city": "New York"}print(person["name"])  # 输入: John

2、应用get()办法拜访值,get()办法能够依据给定的键来获取对应的值,如果键不存在,会返回None

person = {"name": "John", "age": 25, "city": "New York"}print(person.get("name"))  # 输入: John

3、应用keys()办法遍历所有键,keys()办法返回一个蕴含字典所有键的迭代器,能够用于遍历所有键。

person = {"name": "John", "age": 25, "city": "New York"}for key in person.keys():   print(key)  # 输入: name, age, city

4、应用values()办法遍历所有值,values()办法返回一个蕴含字典所有值的迭代器,能够用于遍历所有值。

person = {"name": "John", "age": 25, "city": "New York"}for value in person.values():   print(value)  # 输入: John, 25, New York

5、应用items()办法遍历所有键值对,items()办法返回一个蕴含字典所有键值对的迭代器,能够用于遍历所有键值对。

person = {"name": "John", "age": 25, "city": "New York"}for key, value in person.items():   print(key, value)  # 输入: name John, age 25, city New York

以上这些形式都是一些拜访字典的罕用办法,你能够依据具体需要来拜访字典中的数据。如果键不存在,应用方括号的形式会引发KeyError异样,而get()办法会返回None,须要在代码中做好判断。因而,依据理论状况抉择适合的拜访形式是很重要的。

批改字典

批改字典,次要就是批改字典中的元素。在Python中,能够通过以下形式批改字典中的值:

1、通过键间接赋值批改值,利用方括号和键的形式,能够间接通过赋值操作批改字典中对应键的值。

person = {"name": "John", "age": 25, "city": "New York"}person["name"] = "Tom"print(person)  # 输入: {"name": "Tom", "age": 25, "city": "New York"}

2、应用update()办法批量批改键值对,update()办法承受一个字典作为参数,用于同时批改多个键值对。

person = {"name": "John", "age": 25, "city": "New York"}person.update({"name": "Tom", "age": 30})print(person)  # 输入: {"name": "Tom", "age": 30, "city": "New York"}

3、应用setdefault()办法批改值或增加新键值对,setdefault()办法承受两个参数,第一个参数为要设置的键,第二个参数为默认值。如果键存在,则返回对应的值;如果键不存在,则设置该键的值为默认值,并返回默认值。

person = {"name": "John", "age": 25}person.setdefault("city", "New York")print(person)  # 输入: {"name": "John", "age": 25, "city": "New York"}person.setdefault("country", "USA")print(person)  # 输入: {"name": "John", "age": 25, "city": "New York", "country": "USA"}

以上的这些办法都是能够批改字典的,你能够依据具体需要来批改字典中的值。如果键不存在,则新增键值对;如果键存在,则批改对应的值。记住,字典中的键必须是惟一的,如果重复使用雷同的键,则前面的值会笼罩后面的值。

删除字典

在Python中,能够通过以下形式删除字典或字典中的元素:

1、应用del语句删除字典或字典中的键值对,应用del语句后跟字典名和要删除的键,能够删除字典中的键值对。如果应用del语句后跟字典名,则会删除整个字典。

person = {"name": "John", "age": 25, "city": "New York"}del person["age"]  # 删除键为"age"的键值对print(person)  # 输入: {"name": "John", "city": "New York"}del person  # 删除整个字典

2、应用pop()办法删除指定键的键值对并返回其值,pop()办法承受一个键作为参数,用于删除字典中指定键的键值对,并返回该键对应的值。

person = {"name": "John", "age": 25, "city": "New York"}age = person.pop("age")  # 删除键为"age"的键值对并返回值print(person)  # 输入: {"name": "John", "city": "New York"}print(age)  # 输入: 25

3、应用clear()办法清空字典中的所有键值对,clear()办法用于移除字典中的所有元素,使字典变为空字典。

person = {"name": "John", "age": 25, "city": "New York"}person.clear()  # 清空字典print(person)  # 输入: {}

字典的相干函数

以下是整顿的一些对于字典的相干函数,这些办法可用于对字典进行各种操作,如获取值、增加键值对、删除键值对等。如果有谬误的,欢送大家指出。

函数名解释
clear()移除字典中的所有元素。
copy()返回字典的浅复制正本。
fromkeys(seq[, value])创立一个新字典,应用指定的键和每个键对应的值。
get(key[, default])返回字典中指定键的值。如果键不存在,则返回默认值。
items()返回字典中所有键值对的元组视图。
keys()返回字典中所有键的视图。
pop(key[, default])弹出并返回字典中指定键的值。如果键不存在,则返回默认值。
popitem()弹出并返回字典中的一对键值。
setdefault(key[, default])返回字典中指定键的值。如果键不存在,则在字典中增加键并返回默认值。
update([other])将其余字典或键值对更新到字典中。
values()返回字典中所有值的视图。
更多精彩内容,请关注同名公众:一点sir(alittle-sir)