写点什么

Python 数据类型详解:列表、字典、元组与集合的操作指南

  • 2024-12-24
    北京
  • 本文字数:4674 字

    阅读完需:约 15 分钟

Python 数据类型详解:列表、字典、元组与集合的操作指南

本文详细介绍了 Python 中常用的数据类型,包括列表(List)、字典(Dict)、元组(Tuple)和集合(Set)。通过丰富的代码示例,展示了如何操作这些数据结构,如从列表中获取、修改元素,字典中按键获取值,元组的不可变特性,以及如何利用集合进行交集、并集与差集操作。此外,文章还介绍了列表和字典在循环中的应用,以及如何通过 popremove 等方法对数据进行动态处理。最后,提供了完整的代码示例与运行结果,帮助读者全面掌握 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']}
复制代码

八 源码地址

国内看 Gitee数据种类.py

国外看 GitHub数据种类.py

引用 莫烦 Python


发布于: 刚刚阅读数: 2
用户头像

敲代码不忘补水 2018-04-26 加入

曾在互联网、金融、电商等多个领域工作,对各行的技术需求了如指掌。对新技术充满好奇,喜欢尝试新鲜事物,保持对生活的热情。

评论

发布
暂无评论
Python 数据类型详解:列表、字典、元组与集合的操作指南_Python_敲代码不忘补水_InfoQ写作社区