Python常用数据结构——字典的应用

简介: Python常用数据结构——字典的应用

字典

Python 中,字典(dictionary)是一种无序的数据类型,用于存储键值对。字典中的键,可以是数字、字符串、元组等,但一般用字符串来表示,键与键值之间用冒号分开。以下是一些常见的字典用法:

**创建字典**
# 创建一个空字典
my_dict = {
   }

# 创建带有初始键值对的字典
my_dict = {
   "name": "Alice", "age": 30, "city": "New York", "Score":"A", "Grade":"8"}

# 注意:字典中的键必须是唯一的,并且不可变;字典中的值可以不唯一,也可以变。
AI 代码解读

访问字典元素

# 创建带有初始键值对的字典
my_dict = {
   "Name": "Alice", "Age": 30, "City": "New York", "Score":"A", "Grade":"8"}
print('姓名:', my_dict['Name'])
print('年龄:', my_dict['Age'])
print('年级:', my_dict['Grade'])
print('学习成绩:', my_dict['Score'])
print('\n字典所有值是:', tuple(my_dict.values())) #以元组方式返回字典中所有值
print('\n字典所有的键是:', list(my_dict.keys()))  # 以列表方式返回字典中的所有键
print('\n字典所有值和键是:%s' % my_dict.items())  # 利用items()方法同时访问字典中的值和键
AI 代码解读

运行结果如下:

姓名: Alice
年龄: 30
年级: 8
学习成绩: A

字典所有值是: ('Alice', 30, 'New York', 'A', '8')

字典所有的键是: ['Name', 'Age', 'City', 'Score', 'Grade']

字典所有值和键是:dict_items([('Name', 'Alice'), ('Age', 30), ('City', 'New York'), ('Score', 'A'), ('Grade', '8')])
AI 代码解读

添加和修改元素

# 字典
my_dict = {
   '姓名': '赵杰', '年龄': 22, '年级': '大一', '学习成绩': '优'}
# 添加新键值对
my_dict["email"] = "alice_123@example.com"

# 修改值
my_dict["年龄"] = 31


运行结果如下:
{
   '姓名': '赵杰', '年龄': 31, '年级': '大一', '学习成绩': '优', 'email': 'alice_123@example.com' 
}
AI 代码解读

删除元素

# 删除指定键的键值对
del my_dict["学习成绩"]

# 清空字典
my_dict.clear()

运行结果如下:
删除某项数据后:dict_items([('姓名', '赵杰'), ('年龄', 31), ('年级', '大一'), ('email', 'alice_123@example.com')])
清空所有数据后字典是:{
   }
AI 代码解读

判断键是否存在

# 使用 in 运算符判断键是否存在
if "name" in my_dict:
    print("Key 'name' exists.")
AI 代码解读

遍历字典

# 遍历键
for key in my_dict:
    print(key)

# 遍历值
for value in my_dict.values():
    print(value)

# 遍历键值对
for key, value in my_dict.items():
    print(key, value)
AI 代码解读

示例代码如下:

my_dict = {
   '姓名': '赵杰', '年龄': 22, '年级': '大一', '学习成绩': '优'}
for i, j in my_dict.items():
    print(i,':', j)

运行结果如下:
姓名 : 赵杰
年龄 : 22
年级 : 大一
学习成绩 : 优
AI 代码解读

字典的函数和方法
在 Python 中,字典(dictionary)是一个非常有用的数据结构,提供了许多内置函数和方法来操作和处理字典。以下是一些常用的字典函数和方法:

len():返回字典中键值对的数量。

my_dict = {
   "name": "Alice", "age": 30, "city": "New York"}
print(len(my_dict))  # 输出: 3
AI 代码解读

keys():返回字典中所有键的视图。

keys = my_dict.keys()
print(keys)  # 输出: dict_keys(['name', 'age', 'city'])
AI 代码解读

values():返回字典中所有值的视图。

values = my_dict.values()
print(values)  # 输出: dict_values(['Alice', 30, 'New York'])
AI 代码解读

items():返回字典中所有键值对的元组视图。

items = my_dict.items()
print(items)  # 输出: dict_items([('name', 'Alice'), ('age', 30), ('city', 'New York')])
AI 代码解读
get(key, default=None):获取指定键的值,如果键不存在则返回默认值。
age = my_dict.get("age", 0)
print(age)  # 输出: 30
AI 代码解读

pop(key, default=None):删除指定键并返回其对应的值,如果键不存在并且没有提供默认值,则引发 KeyError 错误。

city = my_dict.pop("city")
print(city)  # 输出: New York
AI 代码解读

.

update(other_dict):将另一个字典的键值对更新到当前字典中。
other_dict = {
   "email": "alice@example.com", "country": "USA"}
my_dict.update(other_dict)
print(my_dict)  # 输出: {
   'name': 'Alice', 'age': 30, 'email': 'alice@example.com', 'country': 'USA'}
AI 代码解读

这些是一些常用的字典函数和方法,可以帮助你更好地操作和利用字典数据结构。

实例:利用字典实现用户注册功能
以下是一个简单的示例,演示如何利用字典实现用户注册功能。在这个示例中,我们将用户的用户名作为键,密码作为对应的值存储在字典中,以模拟用户注册过程。

# 创建一个空字典来存储用户信息
user_credentials = {
   'num1':{
   "name":"admin", "passwd888":"admin", "sex":"1"},}

# 字典的初始值
list1 = []  #定义一个空列表
for num, info in user_credentials.items(): # 利用双for循环,提出嵌套字典中的数据
    for key, value in info.items():
        list1.append(value) # 把字典中的数据添加到列表中
print("用户注册之前信息: ", user_credentials)
print(" 用户的创建 ".center(60, "*"))

print(" 注册 ".center(60, "*"))

name = input("请输入注册姓名:") # 利用input()函数输入注册姓名
if not name in list1[0]: # 如果姓名没有在user_credentials中,就可以继续输入其他信息
    passwd = input('请输入注册密码:')
    sex = input('请输入性别:0 表示 ”女", 1表示"男":')
    user_credentials["num2"] = {
   "name": name, "passwd":passwd, "sex":sex} # 向字典中添加数据
    print("新用户注册成功!")
    print("新用户注册成功后的信息:", user_credentials)
else:
    print("该用户名已经注册,对不起!")



# 显示当前注册的用户信息
print("Registered Users:")
for username, password in user_credentials.items():
    print(f"Username: {username}, Password: {password}")
AI 代码解读

运行结果如下图所示:

运行界面
image.png

录入信息

image.png

显示添加后的信息
image.png

已经存在的用户

image.png

在上面的示例中,register_user() 函数用于注册新用户。如果用户已经存在,则会显示错误消息;否则,将用户名和密码添加到字典中表示成功注册。最后,我们遍历字典,显示当前所有注册用户的用户名和密码信息。

请注意,这只是一个简单的示例,实际开发中需要考虑更多安全性和复杂性方面的问题,例如加密密码、验证输入等。

以上是字典的基本用法。字典是 Python 中非常灵活和强大的数据结构,适合存储各种键值对信息。

实例:利用字典实现用户登陆功能
以下是一个示例代码,演示如何结合 while 循环来实现用户登录功能,并限制登录尝试次数不超过3次:

# 定义一个嵌套字典变量
registered_users = {
   "num1": {
   "name": "赵杰", "passwd": "12345", "sex": "1"},
                    "num2": {
   "name": "admin", "passwd": "password123", "sex": "0"}, }



def login():
    login_attempts = 0  # 定义整型变量,用于统计次数
    max_attempts = 3  # 限制登录尝试次数不超过3while login_attempts < max_attempts:
        username = input("请输入用户姓名: ")

        if username not in list1[0]:
            print("用户不存在,请重新输入!")
            login_attempts += 1
            if max_attempts - login_attempts == 0:
                print("超过最大登录次数!请稍后再试试.")
            else:
                print(f'登录失败! 你还有 {max_attempts - login_attempts}次机会,(共有3次机会)。')

        else:
            password = input("请输入用户密码: ")
            if password == list2[0]:
                print("登录成功! 欢迎, " + username + "!")
            else:
                print("用户密码不对,请重新输入!")
                login_attempts += 1
                if max_attempts - login_attempts == 0:
                    print("超过最大登录次数!请稍后再试试.")
                else:
                    print(f'登录失败! 你还有 {max_attempts - login_attempts}次机会,(共有3次机会)。')


if __name__ == '__main__':
    # 定义两个空列表
    list1 = []
    list2 = []
    for key1, value1 in registered_users.items():
        list1.append(value1['name'])  # 添加用户姓名
        list2.append(value1['passwd'])  # 添加用户密码

    print("用户登录系统".center(50, "*"))
    login()
AI 代码解读

运行结果如下图所示:

如果用户名不存在,如下图所示:

image.png
image.png
image.png

如果输入的用户存在,但连续3次密码错误,也会显示登录失败,如下图所示:

image.png
image.png

如果输入的用户名存在,密码也对,就会显示登录成功,如下图所示:

image.png

在上面的示例中,我们使用 while 循环来控制登录尝试次数不超过3次。用户输入用户名和密码后,调用 login() 函数进行验证。如果登录成功,则打印欢迎消息并跳出循环;如果登录失败,则增加登录尝试次数。如果达到最大尝试次数仍未成功登录,将提示 "超过最大登录次数!请稍后再试试。“

这样的方式可以限制用户登录尝试次数,增强系统的安全性。

目录
打赏
0
2
2
0
220
分享
相关文章
Python数据结构:列表、元组、字典、集合
Python 中的列表、元组、字典和集合是常用数据结构。列表(List)是有序可变集合,支持增删改查操作;元组(Tuple)与列表类似但不可变,适合存储固定数据;字典(Dictionary)以键值对形式存储,无序可变,便于快速查找和修改;集合(Set)为无序不重复集合,支持高效集合运算如并集、交集等。根据需求选择合适的数据结构,可提升代码效率与可读性。
从集思录可转债数据探秘:Python与C++实现的移动平均算法应用
本文探讨了如何利用移动平均算法分析集思录提供的可转债数据,帮助投资者把握价格趋势。通过Python和C++两种编程语言实现简单移动平均(SMA),展示了数据处理的具体方法。Python代码借助`pandas`库轻松计算5日SMA,而C++代码则通过高效的数据处理展示了SMA的计算过程。集思录平台提供了详尽且及时的可转债数据,助力投资者结合算法与社区讨论,做出更明智的投资决策。掌握这些工具和技术,有助于在复杂多变的金融市场中挖掘更多价值。
63 12
通义灵码AI程序员实战:从零构建Python记账本应用的开发全解析
本文通过开发Python记账本应用的真实案例,展示通义灵码AI程序员2.0的代码生成能力。从需求分析到功能实现、界面升级及测试覆盖,AI程序员展现了需求转化、技术选型、测试驱动和代码可维护性等核心价值。文中详细解析了如何使用Python标准库和tkinter库实现命令行及图形化界面,并生成单元测试用例,确保应用的稳定性和可维护性。尽管AI工具显著提升开发效率,但用户仍需具备编程基础以进行调试和优化。
271 9
基于 Python 的布隆过滤器算法在内网行为管理中的应用探究
在复杂多变的网络环境中,内网行为管理至关重要。本文介绍布隆过滤器(Bloom Filter),一种高效的空间节省型概率数据结构,用于判断元素是否存在于集合中。通过多个哈希函数映射到位数组,实现快速访问控制。Python代码示例展示了如何构建和使用布隆过滤器,有效提升企业内网安全性和资源管理效率。
53 9
☀☀☀☀☀☀☀有关栈和队列应用的oj题讲解☼☼☼☼☼☼☼
### 简介 本文介绍了三种数据结构的实现方法:用两个队列实现栈、用两个栈实现队列以及设计循环队列。具体思路如下: 1. **用两个队列实现栈**: - 插入元素时,选择非空队列进行插入。 - 移除栈顶元素时,将非空队列中的元素依次转移到另一个队列,直到只剩下一个元素,然后弹出该元素。 - 判空条件为两个队列均为空。 2. **用两个栈实现队列**: - 插入元素时,选择非空栈进行插入。 - 移除队首元素时,将非空栈中的元素依次转移到另一个栈,再将这些元素重新放回原栈以保持顺序。 - 判空条件为两个栈均为空。
Chainlit:一个开源的异步Python框架,快速构建生产级对话式 AI 应用
Chainlit 是一个开源的异步 Python 框架,帮助开发者在几分钟内构建可扩展的对话式 AI 或代理应用,支持多种工具和服务集成。
301 9
Python 在企业级应用中的两大硬伤
关系数据库和SQL在企业级应用中面临诸多挑战,如复杂SQL难以移植、数据库负担重、应用间强耦合等。Python虽是替代选择,但在大数据运算和版本管理方面存在不足。SPL(esProc Structured Programming Language)作为开源语言,专门针对结构化数据计算,解决了Python的这些硬伤。它提供高效的大数据运算能力、并行处理、高性能文件存储格式(如btx、ctx),以及一致的版本管理,确保企业级应用的稳定性和高性能。此外,SPL与Java无缝集成,适合现代J2EE体系应用,简化开发并提升性能。
|
5月前
|
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
485 9
|
5月前
|
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
72 1
|
3月前
|
【C++数据结构——栈与队列】顺序栈的基本运算(头歌实践教学平台习题)【合集】
本关任务:编写一个程序实现顺序栈的基本运算。开始你的任务吧,祝你成功!​ 相关知识 初始化栈 销毁栈 判断栈是否为空 进栈 出栈 取栈顶元素 1.初始化栈 概念:初始化栈是为栈的使用做准备,包括分配内存空间(如果是动态分配)和设置栈的初始状态。栈有顺序栈和链式栈两种常见形式。对于顺序栈,通常需要定义一个数组来存储栈元素,并设置一个变量来记录栈顶位置;对于链式栈,需要定义节点结构,包含数据域和指针域,同时初始化栈顶指针。 示例(顺序栈): 以下是一个简单的顺序栈初始化示例,假设用C语言实现,栈中存储
178 77
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等