推荐:使用 NSDT场景编辑器 快速搭建3D应用场景
在学习如何编程时,无论您使用此任务的特定编程语言,您都会发现您新选择的学科中有几个主要主题,您接触到的大部分内容都可以归类为这些主题。其中一些,按照一般的顺序,是:语法(语言的词汇);命令(将词汇组合成有用的方式);流控制(我们如何指导命令执行的顺序);算法(我们为解决特定问题而采取的步骤...这怎么会变成一个如此令人困惑的词?最后,数据结构(我们在执行算法期间用于数据操作的虚拟存储库(再次......一系列步骤)。
从本质上讲,如果你想实现问题的解决方案,通过将一系列命令拼凑到算法的步骤中,在某些时候需要处理数据,并且数据结构将变得必不可少。此类数据结构提供了一种有效组织和存储数据的方法,对于创建可以执行有用功能和良好扩展的快速模块化代码至关重要。Python是一种特殊的编程语言,具有一系列自己的内置数据结构。
本教程将重点介绍以下四种基本的 Python 数据结构:
除了基本的数据结构之外,Python 还提供了更高级的结构,例如堆、队列和链表,这可以进一步增强您的编码能力。这些高级结构建立在基础结构之上,可实现更复杂的数据处理,并且通常用于专用方案。但你在这里不受限制;您也可以使用所有现有结构作为基础来实现自己的结构。但是,对列表、元组、字典和集合的理解仍然至关重要,因为这些是更高级数据结构的构建块。
本指南旨在提供对这些核心结构的清晰简洁的理解。当您开始 Python 之旅时,以下部分将指导您完成基本概念和实际应用。从创建和操作列表到利用集合的独特功能,本教程将为您提供在编码中脱颖而出所需的技能。
Python 中的列表是一种有序的可变数据类型,可以存储各种对象,允许重复元素。列表使用方括号定义,元素用逗号分隔。[ ]
例如:
fibs = [0, 1, 1, 2, 3, 5, 8, 13, 21]
列表对于组织和存储数据序列非常有用。
列表可以包含不同的数据类型,如字符串、整数、布尔值等。例如:
mixed_list = [42, "Hello World!", False, 3.14159]
可以访问、添加、更改和删除列表中的元素。例如:
# Access 2nd element (indexing begins at '0')
print(mixed_list[1])
# Append element
mixed_list.append("This is new")
# Change element
mixed_list[0] = 5
# Remove last element
mixed_list.pop(0)
一些方便的列表内置方法包括:
sort()
- 就地排序列表append()
- 将元素添加到列表末尾insert()
- 在索引处插入元素pop()
- 删除索引处的元素remove()
- 删除第一次出现的值reverse()
- 就地反转列表# Create shopping cart as a list
cart = ["apples", "oranges", "grapes"]
# Sort the list
cart.sort()
# Add new item
cart.append("blueberries")
# Remove first item
cart.pop(0)
print(cart)
输出:
['grapes', 'oranges', 'blueberries']
元组是 Python 中的另一种序列数据类型,类似于列表。但是,与列表不同,元组是不可变的,这意味着它们的元素一旦创建就无法更改。它们通过将元素括在括号中来定义。( )
# Defining a tuple
my_tuple = (1, 2, 3, 4)
元组通常用于不应修改的项的集合。元组比列表快,这使得它们非常适合只读操作。一些常见的用例包括:
访问元组中的元素的方式与访问列表元素的方式类似。索引和切片的工作方式相同。
# Accessing elements
first_element = my_tuple[0]
sliced_tuple = my_tuple[1:3]
由于元组是不可变的,因此许多列表操作都适用或不适用。但是,您仍然可以执行某些操作:append()
remove()
+
concatenated_tuple = my_tuple + (5, 6)
*
repeated_tuple = my_tuple * 2
in
exists = 1 in my_tuple
与列表相比,元组具有较少的内置方法,因为它们不可变。一些有用的方法包括:
计数()
:计算特定元素的出现次数。count_of_ones = my_tuple.count(1)
索引()
:查找值第一次出现的索引。index_of_first_one = my_tuple.index(1)
元组打包和解包是 Python 中方便的功能:
packed_tuple = 1, 2, 3
a, b, c = packed_tuple
虽然元组本身是不可变的,但它们可以包含可变元素,如列表。
# Tuple with mutable list
complex_tuple = (1, 2, [3, 4])
请注意,虽然您无法更改元组本身,但您可以修改其中的可变元素。
Python 中的字典是一种无序、可变的数据类型,用于存储唯一键到值的映射。字典是用大括号编写的,由逗号分隔的键值对组成。{ }
例如:
student = {"name": "Michael", "age": 22, "city": "Chicago"}
字典对于以结构化方式存储数据和按键访问值非常有用。
字典键必须是不可变的对象,如字符串、数字或元组。字典值可以是任何对象。
student = {"name": "Susan", "age": 23}
prices = {"milk": 4.99, "bread": 2.89}
可以通过键访问、添加、更改和删除元素。
# Access value by key
print(student["name"])
# Add new key-value
student["major"] = "computer science"
# Change value
student["age"] = 25
# Remove key-value
del student["city"]
一些有用的内置方法包括:
keys()
- 返回键列表values()
- 返回值列表items()
- 返回(键、值)元组get()
- 返回键的值,避免键错误pop()
- 删除键并返回值update()
- 添加多个键值scores = {"Francis": 95, "John": 88, "Daniel": 82}
# Add new score
scores["Zoey"] = 97
# Remove John's score
scores.pop("John")
# Get Daniel's score
print(scores.get("Daniel"))
# Print all student names
print(scores.keys())
Python 中的集合是唯一、不可变对象的无序、可变集合。集合是用大括号编写的,但与字典不同,它没有键值对。{ }
例如:
numbers = {1, 2, 3, 4}
集合对于成员资格测试、消除重复项和数学运算非常有用。
可以通过将集合传递给构造函数来从列表创建集合:set()
my_list = [1, 2, 3, 3, 4]
my_set = set(my_list) # {1, 2, 3, 4}
集合可以包含混合数据类型,如字符串、布尔值等。
可以在集合中添加和删除元素。
numbers.add(5)
numbers.remove(1)
一些有用的集合操作包括:
union()
- 两组的返回并集intersection()
- 返回集合的交集difference()
- 返回集合之间的差异symmetric_difference()
- 返回对称差分A = {1, 2, 3, 4}
B = {2, 3, 5, 6}
# Union - combines sets
print(A | B)
# Intersection
print(A & B)
# Difference
print(A - B)
# Symmetric difference
print(A ^ B)
以下是我们在本教程中提到的四种 Python 数据结构的简要比较。
结构 | 命令 | 可变 | 重复元素 | 使用案例 |
---|---|---|---|---|
列表 | 是的 | 是的 | 是的 | 存储序列 |
元 | 是的 | 不 | 是的 | 存储不可变序列 |
字典 | 不 | 是的 | 键:否 值:是 |
存储键值对 |
设置 | 不 | 是的 | 不 | 消除重复,成员测试 |
将此视为在特定情况下首先转向哪种结构的软指南。
让我们看一下这些结构如何在一个比单行稍微复杂的示例中协同工作。
# Make a list of person names
names = ["John", "Mary", "Bob", "Mary", "Sarah"]
# Make a tuple of additional information (e.g., email)
additional_info = ("[email protected]", "[email protected]", "[email protected]", "[email protected]", "[email protected]")
# Make set to remove duplicates
unique_names = set(names)
# Make dictionary of name-age pairs
persons = {}
for name in unique_names:
persons[name] = random.randint(20,40)
print(persons)
输出:
{'John': 34, 'Bob': 29, 'Sarah': 25, 'Mary': 21}
此示例使用一个列表来存储有序序列,一个元组用于存储其他不可变信息,一个集合用于删除重复项,以及一个字典来存储键值对。
在这个全面的教程中,我们深入探讨了 Python 中的基础数据结构,包括列表、元组、字典和集合。这些结构构成了 Python 编程的构建块,为数据存储、处理和操作提供了框架。了解这些结构对于编写高效且可扩展的代码至关重要。从使用列表操作序列,到使用字典中的键值对组织数据,以及确保集合的唯一性,这些基本工具在数据处理方面提供了极大的灵活性。
原文链接:Python数据结构5步入门 (mvrlink.com)