Python 数据类型详解:列表、字典、元组与集合的操作指南
作者:敲代码不忘补水
- 2024-12-24 北京
本文字数:4674 字
阅读完需:约 15 分钟

本文详细介绍了 Python 中常用的数据类型,包括列表(List)、字典(Dict)、元组(Tuple)和集合(Set)。通过丰富的代码示例,展示了如何操作这些数据结构,如从列表中获取、修改元素,字典中按键获取值,元组的不可变特性,以及如何利用集合进行交集、并集与差集操作。此外,文章还介绍了列表和字典在循环中的应用,以及如何通过 pop、remove 等方法对数据进行动态处理。最后,提供了完整的代码示例与运行结果,帮助读者全面掌握 Python 的基础数据操作。
一 List 列表
# List 列表 files = ["f1.txt", "f2.txt", "f3.txt", "f4.txt", "f5.txt"] print("files[0] ", files[0]) print("files[3] ", files[3]) print("files[-1] ", files[-1]) print("files[-3] ", files[-3]) print()
复制代码
1 获取 List 中多个数据
# 获取多个数据 print("files[:3] ", files[:3]) print("files[2:4] ", files[2:4]) print("files[-3:] ", files[-3:]) print()
复制代码
2 修改 List 对应位置的数据
# 修改对应位置的数据 print("old files[1] ", files[1]) files[1] = 12 print("new files[1] ", files[1]) print()
复制代码
3 List 列表中的存储类型
在列表中,你可以存放不同类型的元素,字符,数字,甚至列表里还能有列表。
# 在列表中,你可以存放不同类型的元素,字符,数字,甚至列表里还能有列表。 l = [1, "file", ["2", 3.2]] print(l) l[2][0] = "new string" print(l) print()
复制代码
4 其他功能
1)扩充入另一个列表
files = ["f1.txt", "f2.txt"]files.extend(["f3.txt", "f4.txt"])print("extend", files)
复制代码
2)按位置添加
files.insert(1, "file5.txt") # 添加入第1位(首位是0哦)print("insert", files)
复制代码
3)移除某索引
del files[1]print("del", files)
复制代码
4) 移除某值
files.remove("f3.txt")print("remove", files)
复制代码
二 Dict 字典
Dict 字典,在字典中的元素不像列表,字典元素是没有顺序的
# Dict 字典,在字典中的元素不像列表,字典元素是没有顺序的 files = {"ID": 111, "passport": "my passport", "books": [1, 2, 3]} print(files) print(files["books"]) print() files["ID"] = 222 print(files) files["ID"] = [2,3,4] print(files) print()
复制代码
1 其他功能
1)按 key 获取对应的 value
按 key 拿取,并在拿取失败的时候给一个设定好的默认值
files = {"ID": 111, "passport": "my passport", "books": [1, 2, 3]}
print('files["ID"]:', files["ID"])print('files.get("ID"):', files.get("unknown ID", "不存在这个 ID"))
复制代码
2)将另一个字典补充到当前字典
files.update({"files": ["1", "2"]})print('update:', files)
复制代码
3)pop 调一个 item,和列表的 pop 类似
popped = files.pop("ID")print('popped:', popped)print("remain:", files)
复制代码
三 Tuple 元组
Tuple 元组,元组里的数据不可变
# Tuple 元组,元组里的数据不可变 files = ("file1", "file2", "file3") print(files[1]) print() # files[1] = "file4" # 这里会报错
复制代码
四 Set 集合
Set 集合,常用它去去重,在集合中的元素,其实是没有顺序的,集合可以用 ([]),也可以用 {}
# Set 集合,常用它去去重,在集合中的元素,其实是没有顺序的,集合可以用 ([]),也可以用 {} my_files = set(["file1", "file2", "file3"]) print("my_files", my_files) your_files = {"file1", "file3", "file5"} print("your_files", your_files) print("交集 ", your_files.intersection(my_files)) print("并集 ", your_files.union(my_files)) print("补集 ", your_files.difference(my_files)) print()
复制代码
五 列表和字典的数据读取
# 列表在循环中运用 files = ["f1.txt", "f2.txt", "f3.txt", "f4.txt", "f5.txt"] for i in range(len(files)): if files[i] == "f3.txt": print("I got f3.txt") print() # 字典在循环中运用 files = {"ID": 111, "passport": "my passport", "books": [1,2,3]} for key in files.keys(): print("key:", key)
for value in files.values(): print("value:", value)
for key, value in files.items(): print("key:", key, ", value:", value) print()
复制代码
六 补充功能
# 补充功能files = []for i in range(5): files.append("f" + str(i) + ".txt") # 添加 print("has", files)
for i in range(len(files)): print("pop", files.pop()) # 从最后一个开始 pop 出。取出之后当前数据被删除 print("remain", files)
复制代码
七 完整文件示例
# This is a sample Python script.
# Press ⌃R to execute it or replace it with your code.# Press Double ⇧ to search everywhere for classes, files, tool windows, actions, and settings.
def print_hi(name): # Use a breakpoint in the code line below to debug your script. print(f'Hi, {name}') # Press ⌘F8 to toggle the breakpoint. # List 列表 files = ["f1.txt", "f2.txt", "f3.txt", "f4.txt", "f5.txt"] print("files[0] ", files[0]) print("files[3] ", files[3]) print("files[-1] ", files[-1]) print("files[-3] ", files[-3]) print() # 获取多个数据 print("files[:3] ", files[:3]) print("files[2:4] ", files[2:4]) print("files[-3:] ", files[-3:]) print() # 修改对应位置的数据 print("old files[1] ", files[1]) files[1] = 12 print("new files[1] ", files[1]) print() # 在列表中,你可以存放不同类型的元素,字符,数字,甚至列表里还能有列表。 l = [1, "file", ["2", 3.2]] print(l) l[2][0] = "new string" print(l) print()
# Dict 字典,在字典中的元素不像列表,字典元素是没有顺序的 files = {"ID": 111, "passport": "my passport", "books": [1, 2, 3]} print(files) print(files["books"]) print() files["ID"] = 222 print(files) files["ID"] = [2, 3, 4] print(files) print() # Tuple 元组,元组里的数据不可变 files = ("file1", "file2", "file3") print(files[1]) print() # files[1] = "file4" # 这里会报错
# Set 集合,常用它去去重,在集合中的元素,其实是没有顺序的,集合可以用 ([]),也可以用 {} my_files = set(["file1", "file2", "file3"]) print("my_files", my_files) your_files = {"file1", "file3", "file5"} print("your_files", your_files) print("交集 ", your_files.intersection(my_files)) print("并集 ", your_files.union(my_files)) print("补集 ", your_files.difference(my_files)) print() # 列表在循环中运用 files = ["f1.txt", "f2.txt", "f3.txt", "f4.txt", "f5.txt"] for i in range(len(files)): if files[i] == "f3.txt": print("I got f3.txt") print() # 字典在循环中运用 files = {"ID": 111, "passport": "my passport", "books": [1, 2, 3]} for key in files.keys(): print("key:", key)
for value in files.values(): print("value:", value)
for key, value in files.items(): print("key:", key, ", value:", value) print() # 其他功能 files = [] for i in range(5): files.append("f" + str(i) + ".txt") # 添加 print("has", files)
for i in range(len(files)): print("pop", files.pop()) # 从最后一个开始 pop 出。取出之后当前数据被删除 print("remain", files)
files = ["f1.txt", "f2.txt"]
# 其他功能list # 扩充入另一个列表 files.extend(["f3.txt", "f4.txt"]) print("extend", files)
# 按位置添加 files.insert(1, "file5.txt") # 添加入第1位(首位是0哦) print("insert", files)
# 移除某索引 del files[1] print("del", files)
# 移除某值 files.remove("f3.txt") print("remove", files)
# 其他功能字典 files = {"ID": 111, "passport": "my passport", "books": [1, 2, 3]}
# 按key拿取,并在拿取失败的时候给一个设定好的默认值 print('files["ID"]:', files["ID"]) print('files.get("ID"):', files.get("unknown ID", "不存在这个 ID"))
# 将另一个字典补充到当前字典 files.update({"files": ["1", "2"]}) print('update:', files)
# pop 调一个item,和列表的 pop 类似 popped = files.pop("ID") print('popped:', popped) print("remain:", files)
# Press the green button in the gutter to run the script.if __name__ == '__main__': print_hi('数据种类')
# See PyCharm help at https://www.jetbrains.com/help/pycharm/
复制代码
复制粘贴并覆盖到你的 main.py 中运行,运行结果如下。
Hi, 数据种类files[0] f1.txtfiles[3] f4.txtfiles[-1] f5.txtfiles[-3] f3.txt
files[:3] ['f1.txt', 'f2.txt', 'f3.txt']files[2:4] ['f3.txt', 'f4.txt']files[-3:] ['f3.txt', 'f4.txt', 'f5.txt']
old files[1] f2.txtnew files[1] 12
[1, 'file', ['2', 3.2]][1, 'file', ['new string', 3.2]]
{'ID': 111, 'passport': 'my passport', 'books': [1, 2, 3]}[1, 2, 3]
{'ID': 222, 'passport': 'my passport', 'books': [1, 2, 3]}{'ID': [2, 3, 4], 'passport': 'my passport', 'books': [1, 2, 3]}
file2
my_files {'file3', 'file1', 'file2'}your_files {'file5', 'file1', 'file3'}交集 {'file1', 'file3'}并集 {'file5', 'file3', 'file1', 'file2'}补集 {'file5'}
I got f3.txt
key: IDkey: passportkey: booksvalue: 111value: my passportvalue: [1, 2, 3]key: ID , value: 111key: passport , value: my passportkey: books , value: [1, 2, 3]
has ['f0.txt']has ['f0.txt', 'f1.txt']has ['f0.txt', 'f1.txt', 'f2.txt']has ['f0.txt', 'f1.txt', 'f2.txt', 'f3.txt']has ['f0.txt', 'f1.txt', 'f2.txt', 'f3.txt', 'f4.txt']pop f4.txtremain ['f0.txt', 'f1.txt', 'f2.txt', 'f3.txt']pop f3.txtremain ['f0.txt', 'f1.txt', 'f2.txt']pop f2.txtremain ['f0.txt', 'f1.txt']pop f1.txtremain ['f0.txt']pop f0.txtremain []extend ['f1.txt', 'f2.txt', 'f3.txt', 'f4.txt']insert ['f1.txt', 'file5.txt', 'f2.txt', 'f3.txt', 'f4.txt']del ['f1.txt', 'f2.txt', 'f3.txt', 'f4.txt']remove ['f1.txt', 'f2.txt', 'f4.txt']files["ID"]: 111files.get("ID"): 不存在这个 IDupdate: {'ID': 111, 'passport': 'my passport', 'books': [1, 2, 3], 'files': ['1', '2']}popped: 111remain: {'passport': 'my passport', 'books': [1, 2, 3], 'files': ['1', '2']}
复制代码
八 源码地址
引用 莫烦 Python
划线
评论
复制
发布于: 刚刚阅读数: 2
版权声明: 本文为 InfoQ 作者【敲代码不忘补水】的原创文章。
原文链接:【http://xie.infoq.cn/article/5e2993c8adad6586a2d0bf64d】。文章转载请联系作者。
敲代码不忘补水
关注
敲代码不忘补水 2018-04-26 加入
曾在互联网、金融、电商等多个领域工作,对各行的技术需求了如指掌。对新技术充满好奇,喜欢尝试新鲜事物,保持对生活的热情。









评论