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

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

文章目录

  • Python 数据类型详解:列表、字典、元组与集合的操作指南
      • 一 List 列表
        • 1 获取 List 中多个数据
        • 2 修改 List 对应位置的数据
        • 3 List 列表中的存储类型
        • 4 其他功能
          • 1)扩充入另一个列表
          • 2)按位置添加
          • 3)移除某索引
          • 4) 移除某值
      • 二 Dict 字典
        • 1 其他功能
          • 1)按 key 获取对应的 value
          • 2)将另一个字典补充到当前字典
          • 3)pop 调一个item,和列表的 pop 类似
      • 三 Tuple 元组
      • 四 Set 集合
      • 五 列表和字典的数据读取
      • 六 补充功能
      • 七 完整文件示例
      • 八 源码地址

本文详细介绍了 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.txt
files[3]  f4.txt
files[-1]  f5.txt
files[-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.txt
new 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: ID
key: passport
key: books
value: 111
value: my passport
value: [1, 2, 3]
key: ID , value: 111
key: passport , value: my passport
key: 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.txt
remain ['f0.txt', 'f1.txt', 'f2.txt', 'f3.txt']
pop f3.txt
remain ['f0.txt', 'f1.txt', 'f2.txt']
pop f2.txt
remain ['f0.txt', 'f1.txt']
pop f1.txt
remain ['f0.txt']
pop f0.txt
remain []
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"]: 111
files.get("ID"): 不存在这个 ID
update: {'ID': 111, 'passport': 'my passport', 'books': [1, 2, 3], 'files': ['1', '2']}
popped: 111
remain: {'passport': 'my passport', 'books': [1, 2, 3], 'files': ['1', '2']}

八 源码地址

代码地址:GitHub 之 数据种类.py

详情见:莫烦 Python

你可能感兴趣的:(Python,编码,python,windows,开发语言)