引言
python小程序之打印输入的列表内容以及列表去重的两种方法
文章目录
- 引言
- 一、打印输入的列表内容
- 1.1 题目
- 1.2 代码
- 1.3 代码解释
- 二、列表去重
- 2.1 题目
- 2.2 代码
- 2.2.1 set格式转换
- 2.2.2 for循环添加到新列表
- 2.3 代码解释
- 2.3.1 set形式
- 2.3.2 for循环
- 三、思考
- 3.1 打印输入的列表内容
- 3.2 列表去重
一、打印输入的列表内容
1.1 题目
通过 input输⼊3个人信息,每个⼈有姓名和年龄,将信息存⼊字典中,并将将字典存⼊列表。
遍历列表,打印每个⼈的信息,打印格式如下:
张三 20
李四 22
王五 23
1.2 代码
# 通过 input输⼊3个⼈信息,每个⼈有姓名和年龄,将信息存⼊字典中,并将将字典存⼊列表。
# 遍历列表,打印每个⼈的信息,打印格式如下:
# 张三 20
# 李四 22
# 王五 23list_info = []for i in range(3):dic_info = {}name = input('请输入名字:')age = input('请输入年龄:')dic_info['名字'] = namedic_info['年龄'] = agelist_info.append(dic_info)
print(dic_info)
print(list_info)for i in list_info:print(i['名字'], i['年龄'])
输出结果:
1.3 代码解释
这段代码的功能是创建一个包含多个字典的列表,每个字典存储一个人的名字和年龄信息
list_info = []
:初始化一个空列表,用于存储字典信息for i in range(3):
:这是一个循环,将执行3次。range(3)
生成一个包含0, 1, 2的序列dic_info = {}
:在每次循环的开始,初始化一个空字典,用于存储当前输入的名字和年龄name = input('请输入名字:')
:提示用户输入名字,并将输入的字符串赋值给变量name
age = input('请输入年龄:')
:提示用户输入年龄,并将输入的字符串赋值给变量age
dic_info['名字'] = name
:将用户输入的名字添加到dic_info
字典中,键为'名字'
dic_info['年龄'] = age
:将用户输入的年龄添加到dic_info
字典中,键为'年龄'
list_info.append(dic_info)
:将当前循环中创建的dic_info
字典添加到list_info
列表中print(dic_info)
:打印当前循环中创建的dic_info
字典。这个打印语句位于循环内部,因此每次循环都会打印当前输入的字典print(list_info)
:在所有循环完成后,打印整个list_info
列表for i in list_info:
:这是一个循环,用于遍历list_info
列表中的每个字典print(i['名字'], i['年龄'])
:在内部循环中,打印每个字典的'名字'
和'年龄'
键对应的值
整个代码执行后,首先会提示用户三次输入名字和年龄,然后将这些信息存储在列表- 最后,打印出列表中的每个字典,以及每个字典中的名字和年龄
- 需要注意的是,代码中
print(dic_info)
位于循环内部,因此它会打印三次输入的字典信息,而print(list_info)
位于循环外部,所以它只会打印一次完整的列表信息
二、列表去重
2.1 题目
去掉列表里重复的元素(去重)
2.2 代码
2.2.1 set格式转换
list1 = [1, 2, 3, 4, 1, 2, 34, 'qq', 'wx', 'qq']
print(list1)set1 = set(list1)
print(set1)list_uni = list(set1)
print(list_uni)
输出结果:
2.2.2 for循环添加到新列表
list1 = [1, 2, 3, 4, 1, 2, 34, 'qq', 'wx', 'qq']
print(list1)
list_new = []
for i in list1:if i not in list_new:list_new.append(i)print(list_new)
输出结果:
2.3 代码解释
2.3.1 set形式
这段代码的功能是将一个列表转换为集合,从而去除列表中的重复元素,然后再将集合转换回列表
list1 = [1, 2, 3, 4, 1, 2, 34, 'qq', 'wx', 'qq']
:初始化一个列表list1
,其中包含整数和字符串元素,并且有些元素是重复的print(list1)
:打印出原始的列表list1
,输出为:[1, 2, 3, 4, 1, 2, 34, 'qq', 'wx', 'qq']
set1 = set(list1)
:将列表list1
转换为集合set1
。集合是一个无序的不重复元素集,因此在这个过程中,列表中所有的重复元素都被移除了print(set1)
:打印出转换后的集合set1
。由于集合是无序的,输出的元素顺序可能与原始列表不同。输出可能是这样的:{1, 2, 3, 4, 34, 'wx', 'qq'}
list_uni = list(set1)
:将集合set1
转换回列表,并赋值给变量list_uni
。此时,列表中的重复元素已经被去除了print(list_uni)
:打印出转换回列表后的list_uni
。输出将是一个不包含重复元素的列表,但元素的顺序可能与原始列表不同。输出可能是这样的:[1, 2, 3, 4, 34, 'wx', 'qq']
- 总结来说,这段代码展示了如何使用Python中的集合来去除列表中的重复元素。需要注意的是,由于集合是无序的,因此将集合转换回列表时,列表中元素的顺序可能会发生变化
2.3.2 for循环
这段代码的功能是遍历列表
list1
,并创建一个新的列表list_new
,其中仅包含list1
中的非重复元素
list1 = [1, 2, 3, 4, 1, 2, 34, 'qq', 'wx', 'qq']
:初始化一个列表list1
,它包含整数和字符串元素,且有些元素是重复的print(list1)
:打印出原始的列表list1
,输出为:[1, 2, 3, 4, 1, 2, 34, 'qq', 'wx', 'qq']
list_new = []
:初始化一个空列表list_new
,用于存储不重复的元素for i in list1:
:开始一个循环,遍历list1
中的每个元素if i not in list_new:
:在循环内部,检查当前元素i
是否不在list_new
列表中list_new.append(i)
:如果i
不在list_new
中,则将其添加到list_new
列表的末尾
通过这个循环,代码会检查list1
中的每个元素,并且只有当该元素还未出现在list_new
中时,才会将其添加到list_new
。这样,list_new
中就不会有重复的元素print(list_new)
:在循环结束后,打印出新的列表list_new
,这个列表包含了list1
中的所有唯一元素,输出可能是这样的:[1, 2, 3, 4, 34, 'qq', 'wx']
- 需要注意的是,由于这个方法使用了
if i not in list_new
来检查元素是否存在,因此它的效率不是最高的,特别是当list1
很大时,因为每次检查都需要遍历list_new
三、思考
3.1 打印输入的列表内容
- 首先是input输入名字和年龄,多次输入需要用到循环
- 输入的内容因为是一对一的,所以保存在字典中
- 有多条数据,所以需要将每个字典添加到列表中
- 最终是一条记录一条记录依次打印,需要用到循环
3.2 列表去重
- set集合格式可以直接将列表中的元素去重,效率高,但是去重后的列表顺序会不一样
- for循环去重效率不高,每次添加到一个新列表需要遍历原来的列表,但是列表顺序会按照原来的列表顺序