引言

python小程序之打印输入的列表内容以及列表去重的两种方法

一、打印输入的列表内容

1.1 题目

通过 input输⼊3个人信息,每个⼈有姓名和年龄,将信息存⼊字典中,并将将字典存⼊列表。
遍历列表,打印每个⼈的信息,打印格式如下:
张三 20
李四 22
王五 23

1.2 代码

# 通过 input输⼊3个⼈信息,每个⼈有姓名和年龄,将信息存⼊字典中,并将将字典存⼊列表。
# 遍历列表,打印每个⼈的信息,打印格式如下:
# 张三 20
# 李四 22
# 王五 23

list_info = []

for i in range(3):
    dic_info = {}
    name = input('请输入名字:')
    age = input('请输入年龄:')
    dic_info['名字'] = name
    dic_info['年龄'] = age
    list_info.append(dic_info)
print(dic_info)
print(list_info)

for i in list_info:
    print(i['名字'], i['年龄'])

输出结果:
在这里插入图片描述

1.3 代码解释

这段代码的功能是创建一个包含多个字典的列表,每个字典存储一个人的名字和年龄信息

  1. list_info = []:初始化一个空列表,用于存储字典信息
  2. for i in range(3)::这是一个循环,将执行3次。range(3)生成一个包含0, 1, 2的序列
  3. dic_info = {}:在每次循环的开始,初始化一个空字典,用于存储当前输入的名字和年龄
  4. name = input('请输入名字:'):提示用户输入名字,并将输入的字符串赋值给变量name
  5. age = input('请输入年龄:'):提示用户输入年龄,并将输入的字符串赋值给变量age
  6. dic_info['名字'] = name:将用户输入的名字添加到dic_info字典中,键为'名字'
  7. dic_info['年龄'] = age:将用户输入的年龄添加到dic_info字典中,键为'年龄'
  8. list_info.append(dic_info):将当前循环中创建的dic_info字典添加到list_info列表中
  9. print(dic_info):打印当前循环中创建的dic_info字典。这个打印语句位于循环内部,因此每次循环都会打印当前输入的字典
  10. print(list_info):在所有循环完成后,打印整个list_info列表
  11. for i in list_info::这是一个循环,用于遍历list_info列表中的每个字典
  12. print(i['名字'], i['年龄']):在内部循环中,打印每个字典的'名字''年龄'键对应的值
    整个代码执行后,首先会提示用户三次输入名字和年龄,然后将这些信息存储在列表
  13. 最后,打印出列表中的每个字典,以及每个字典中的名字和年龄
  14. 需要注意的是,代码中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形式

这段代码的功能是将一个列表转换为集合,从而去除列表中的重复元素,然后再将集合转换回列表

  1. list1 = [1, 2, 3, 4, 1, 2, 34, 'qq', 'wx', 'qq']:初始化一个列表list1,其中包含整数和字符串元素,并且有些元素是重复的
  2. print(list1):打印出原始的列表list1,输出为:[1, 2, 3, 4, 1, 2, 34, 'qq', 'wx', 'qq']
  3. set1 = set(list1):将列表list1转换为集合set1。集合是一个无序的不重复元素集,因此在这个过程中,列表中所有的重复元素都被移除了
  4. print(set1):打印出转换后的集合set1。由于集合是无序的,输出的元素顺序可能与原始列表不同。输出可能是这样的:{1, 2, 3, 4, 34, 'wx', 'qq'}
  5. list_uni = list(set1):将集合set1转换回列表,并赋值给变量list_uni。此时,列表中的重复元素已经被去除了
  6. print(list_uni):打印出转换回列表后的list_uni。输出将是一个不包含重复元素的列表,但元素的顺序可能与原始列表不同。输出可能是这样的:[1, 2, 3, 4, 34, 'wx', 'qq']
  7. 总结来说,这段代码展示了如何使用Python中的集合来去除列表中的重复元素。需要注意的是,由于集合是无序的,因此将集合转换回列表时,列表中元素的顺序可能会发生变化

2.3.2 for循环

这段代码的功能是遍历列表list1,并创建一个新的列表list_new,其中仅包含list1中的非重复元素

  1. list1 = [1, 2, 3, 4, 1, 2, 34, 'qq', 'wx', 'qq']:初始化一个列表list1,它包含整数和字符串元素,且有些元素是重复的
  2. print(list1):打印出原始的列表list1,输出为:[1, 2, 3, 4, 1, 2, 34, 'qq', 'wx', 'qq']
  3. list_new = []:初始化一个空列表list_new,用于存储不重复的元素
  4. for i in list1::开始一个循环,遍历list1中的每个元素
  5. if i not in list_new::在循环内部,检查当前元素i是否不在list_new列表中
  6. list_new.append(i):如果i不在list_new中,则将其添加到list_new列表的末尾
    通过这个循环,代码会检查list1中的每个元素,并且只有当该元素还未出现在list_new中时,才会将其添加到list_new。这样,list_new中就不会有重复的元素
  7. print(list_new):在循环结束后,打印出新的列表list_new,这个列表包含了list1中的所有唯一元素,输出可能是这样的:[1, 2, 3, 4, 34, 'qq', 'wx']
  8. 需要注意的是,由于这个方法使用了if i not in list_new来检查元素是否存在,因此它的效率不是最高的,特别是当list1很大时,因为每次检查都需要遍历list_new

三、思考

3.1 打印输入的列表内容

  • 首先是input输入名字和年龄,多次输入需要用到循环
  • 输入的内容因为是一对一的,所以保存在字典中
  • 有多条数据,所以需要将每个字典添加到列表中
  • 最终是一条记录一条记录依次打印,需要用到循环

3.2 列表去重

  • set集合格式可以直接将列表中的元素去重,效率高,但是去重后的列表顺序会不一样
  • for循环去重效率不高,每次添加到一个新列表需要遍历原来的列表,但是列表顺序会按照原来的列表顺序
Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐