【编程基础之Python】8、Python复合数据类型

news/2024/11/27 9:35:35/

【编程基础之Python】8、Python复合数据类型

  • Python复合数据类型
    • 列表(List)
      • 创建列表
      • 访问元素
      • 内置方法
      • 列表操作
    • 元组(Tuple)
      • 创建元组
      • 访问元素
    • 集合(Set)
      • 创建集合
      • 基本操作
      • 其他操作
    • 字典(Dictionary)
      • 创建字典
      • 访问元素
      • 基本操作
  • 写在后面

Python复合数据类型

除了上述提到的几种基本数据类型,Python还提供了一些常用的复合数据类型,包括列表(List)、元组(Tuple)、集合(Set)和字典(Dictionary)。

列表(List)

列表是一种有序的数据类型,可以存储多个任意类型的数据。列表使用方括号[ ]来表示,每个元素之间用逗号隔开。

创建列表

下面是一个创建列表的例子:

lst = [1, 2, 3, 'four', 'five']
print(type(lst), lst)

image-20230303105244680

访问元素

列表的元素可以通过索引来访问,索引从0开始。

例如,要访问上面列表中的第一个元素,可以使用以下代码:

lst = [1, 2, 3, 'four', 'five']
print(lst[0])

image-20230303105343566

列表还支持切片操作,可以使用类似于字符串的切片语法来访问其中的元素。

例如,要访问列表中的前三个元素,可以使用以下代码:

lst = [1, 2, 3, 'four', 'five']
print(lst[1:3])

image-20230303105624258

内置方法

除了基本的访问和切片操作,列表还支持一系列的方法,列表有很多常用的方法,下面是一些常用的列表方法:

  • append():向列表末尾添加一个元素。
  • insert():向列表指定位置插入一个元素。
  • remove():从列表中移除指定的元素。
  • pop():从列表末尾移除一个元素。
  • sort():对列表进行排序。
  • reverse():将列表翻转。

接下来是一个例子,展示了如何使用这些方法:

my_list = [1, 2, 3, 4, 5]
print("原始列表:", my_list)
# 添加一个元素
my_list.append(6)
print("添加一个元素:", my_list)
# 在指定位置插入一个元素
my_list.insert(2, "hello")
print("在指定位置插入一个元素:", my_list)
# 移除指定的元素
my_list.remove(4)
print("移除指定的元素:", my_list)
# 移除末尾的元素
my_list.pop()
print("移除末尾的元素:", my_list)
# 对列表进行排序
my_list.sort()
print("对列表进行排序:", my_list)
# 将列表翻转
my_list.reverse()
print("将列表翻转:", my_list)

image-20230303105819394

列表操作

除了列表自身的一些方法外,Python还提供了一些方法可以操作列表:

  • len():求列表中元素的个数。
  • +:合并两个列表。
  • *:重复列表元素。
  • in:判断元素是否在列表内。
  • for:对列表进行遍历。

接下来是一个例子,展示了如何使用这些方法:

my_list1 = [1, 2, 3]
my_list2 = ["A", "B", "C"]
print("原始列表1:", my_list1)
print("原始列表2:", my_list2)
# 求列表长度
ln = len(my_list1)
print("求列表长度:", ln)
# 合并两个列表
my_list3 = my_list1 + my_list2
print("合并两个列表:", my_list3)
# 重复列表元素
my_list4 = my_list1 * 3
print("重复列表元素:", my_list4)
# 判断元素是否在列表内
ex1 = 3 in my_list1
ex2 = 3 in my_list2
print("判断元素是否在列表内:", ex1, ex2)
# 对列表进行遍历
for x in my_list1:print("对列表进行遍历:", x)

image-20230303110202971

元组(Tuple)

元组和列表类似,也是一种有序的数据类型,可以存储多个任意类型的数据。但是元组一旦创建,就不能再修改其中的元素。

元组使用圆括号 ( ) 来表示,每个元素之间用逗号隔开。

创建元组

下面是一个创建元组的例子:

tuple1 = (1, 2, 3, 'four', 'five')
print(tuple1)

image-20230303110655061

访问元素

元组的访问和切片操作和列表类似,也是通过索引和切片语法来实现。

tuple1 = (1, 2, 3, 'four', 'five')
tuple2 = ("A", "B", "C")
print("通过索引访问:", tuple1[2])
print("通过切片访问:", tuple1[1:3])
print("元组长度:", len(tuple1))
print("元素重复:", tuple1 * 3)
print("元组合并:", tuple1 + tuple2)
print("元素判断:", "A" in tuple1, "A" in tuple2)
for x in tuple2:print("对元组进行遍历:", x)

image-20230303111236890

集合(Set)

集合是一种无序、不重复的数据类型,用于去重或者判断一个元素是否存在。集合使用花括号 { } 来表示,每个元素之间用逗号隔开。

创建集合

下面是一个创建集合的例子:

set1 = {1, 2, 3, 'four', 'five'}
print(set1)

image-20230303114356893

基本操作

集合的操作包括添加元素、删除元素、查找、遍历、求并集、交集等。

  • add(element):向集合中添加元素
  • update(set):向集合中添加多个元素,将集合更新为和指定集合的并集
  • discard(element):移除集合中指定的元素
  • remove(element):移除集合中指定的元素,如果不存在则抛出异常
  • pop():随机移除一个元素并返回,由于集合是无序的,因此无法确定删除的是哪个元素
my_set = {1, 2, 3}
# 添加不存在的元素
my_set.add(4)
print("添加不存在的元素:", my_set)
# 添加已经存在的元素
my_set.add(2)
print("添加已经存在的元素:", my_set)
# 向集合中添加多个元素
my_set.update([5, 6])
my_set.update((7, 8))
my_set.update({9, 10})
print("向集合中添加多个元素:", my_set)
# 移除集合中指定的元素
my_set.remove(3)
my_set.discard(5)
pp = my_set.pop()
print("移除集合中指定的元素:", my_set, pp)
for x in my_set:print("遍历集合:", x)

image-20230303115709701

其他操作

可以使用一些内置的方法来对集合进行操作。以下是一些常用的集合方法:

  • clear():清空集合
  • copy():复制集合
  • difference(set):返回集合和指定集合的差集
  • difference_update(set):移除集合中和指定集合相同的元素
  • intersection(set):返回集合和指定集合的交集
  • intersection_update(set):保留集合中和指定集合相同的元素
  • isdisjoint(set):判断两个集合是否没有共同元素
  • issubset(set):判断一个集合是否是另一个集合的子集
  • issuperset(set):判断一个集合是否是另一个集合的超集
  • symmetric_difference(set):返回集合和指定集合的对称差集
  • symmetric_difference_update(set):将集合更新为和指定集合的对称差集
  • union(set):返回集合和指定集合的并集

下面是一些示例代码:

# 创建集合
fruits = {"apple", "banana", "cherry"}
# 添加元素
fruits.add("orange")
print(fruits)  # 输出: {'banana', 'apple', 'orange', 'cherry'}
# 移除元素
fruits.remove("banana")
print(fruits)  # 输出: {'apple', 'orange', 'cherry'}
# 清空集合
fruits.clear()
print(fruits)  # 输出: set()
# 复制集合
fruits = {"apple", "banana", "cherry"}
fruits_copy = fruits.copy()
print(fruits_copy)  # 输出: {'banana', 'apple', 'cherry'}
# 求交集
x = {"apple", "banana", "cherry"}
y = {"google", "microsoft", "apple"}
z = x.intersection(y)
print(z)  # 输出: {'apple'}
# 求并集
x = {"apple", "banana", "cherry"}
y = {"google", "microsoft", "apple"}
z = x.union(y)
print(z)  # 输出: {'banana', 'apple', 'google', 'cherry', 'microsoft'}
# 判断是否是子集
x = {"a", "b", "c"}
y = {"f", "e", "d", "c", "b", "a"}
z = x.issubset(y)
print(z)  # 输出: True

字典(Dictionary)

字典是一种无序的键值对(key-value)数据类型,可以用来存储任意类型的数据。字典使用花括号 { } 来表示,每个键值对之间用冒号 : 隔开,键值对之间用逗号隔开。

创建字典

可以使用花括号 {} 或者 dict() 函数来创建字典。使用花括号创建字典时,键-值对之间用冒号 : 分隔,每个键-值对之间用逗号 , 分隔。

# 使用花括号创建字典
my_dict1 = {'apple': 3, 'banana': 5, 'orange': 2}
print(my_dict1)
# 使用 dict() 函数创建字典
my_dict2 = dict(apple=3, banana=5, orange=2)
print(my_dict2)

image-20230303120531172

访问元素

可以使用键来访问字典中的元素。如果键不存在,则会抛出 KeyError 异常。

my_dict = {'apple': 3, 'banana': 5, 'orange': 2}print(my_dict['apple'])  # 输出 3
print(my_dict['pear'])   # 抛出 KeyError 异常

image-20230303120745655

可以使用 get() 方法来访问字典中的元素。如果键不存在,则会返回 None 或者指定的默认值。

my_dict = {'apple': 3, 'banana': 5, 'orange': 2}print(my_dict.get('apple'))      # 输出 3
print(my_dict.get('pear'))       # 输出 None
print(my_dict.get('pear', 0))    # 输出 0

image-20230303120949098

基本操作

Python字典包含了以下内置方法:

  • clear():删除字典内所有元素
  • copy():返回一个字典的浅复制
  • get(key, default=None):返回指定键的值,如果值不在字典中返回default值。
  • has_key(key):如果键在字典dict里返回true,否则返回false。
  • items():以列表返回可遍历的(键, 值) 元组数组。
  • keys():以列表返回一个字典所有的键。
  • values():以列表返回字典中的所有值。

写在后面

在本篇文章中,我们介绍了Python的几种复合数据类型:列表、元组、集合、字典,同时,我们还讨论了它们的一些操作。


http://www.ppmy.cn/news/29533.html

相关文章

Python解题 - CSDN周赛第33期

本期四道题全考过&#xff0c;题解在网上也都搜得到。。。没有想法&#xff0c;顺手水一份题解吧。 第一题&#xff1a;奇偶排序 给定一个存放整数的数组&#xff0c;重新排列数组使得数组左边为奇数&#xff0c;右边为偶数。 输入描述&#xff1a;第一行输入整数n。(1<n<…

如何从 Android 手机上的 SD 卡恢复已删除的照片

为了扩展手机的存储空间&#xff0c;很多人都会在安卓手机上插入一张SD卡来存储一些大文件&#xff0c;比如电影、照片、视频等。虽然SD卡给我们带来了很大的方便&#xff0c;但我们还是避免不了数据丢失一些事故造成的。您是否正在为 SD 卡上的照片意外丢失而苦恼&#xff1f;…

【C++】多态虚表

多态——多种形态多态的分类&#xff1a;1.静态多态&#xff1a;函数重载和运算符重载&#xff08;复用函数名&#xff09;2.动态多态&#xff1a;派生类和虚函数实现运行时多态静态多态和动态多态的区别&#xff1a;静态多态的函数地址早绑定——编译阶段确定函数地址动态多态…

JVM—类加载子系统

JVM细节版架构图 ​ 本文针对Class Loader SubSystem这一块展开讲解类加载子系统的工作流程 类加载子系统作用 1.类加载子系统负责从文件系统或者网络中加载class文件&#xff0c;class文件在文件开头有特定的文件标识即16进制CA FE BA BE&#xff1b; 2.加载后的Class类信息…

为什么FPGA在深度学习领域有着得天独厚的优势?

01 FPGA在深度学习领域有哪些优势 FPGA&#xff08;Field-Programmable Gate Array&#xff09;是一种灵活的可编程硬件设备&#xff0c;它在深度学习应用领域中具有许多优势。 首先&#xff0c;FPGA具有非常高的并行性。在深度学习中&#xff0c;许多计算都可以并行化&…

【机器学习】决策树(理论)

决策树&#xff08;理论&#xff09; 目录一、何为决策树1、决策树的组成2、决策树的构建二、熵1、熵的作用2、熵的定义3、熵的计算4、条件熵的引入5、条件熵的计算三、划分选择1、信息增益&#xff08; ID3 算法选用的评估标准&#xff09;2、信息增益率&#xff08; C4.5 算法…

后端程序员的前端基础-前端三剑客之HTML

文章目录1 HTML简介1.1 什么是HTML1.2 HTML能做什么1.3 HTML书写规范2 HTML基本标签2.1 结构标签2.2 排版标签2.3 块标签2.4 基本文字标签2.5 文本格式化标签2.6 标题标签2.7 列表标签(清单标签)2.8 图片标签2.9 链接标签2.10 表格标签3 HTML表单标签3.1 form元素常用属性3.2 i…

【微信小程序】-- 网络数据请求(十九)

&#x1f48c; 所属专栏&#xff1a;【微信小程序开发教程】 &#x1f600; 作  者&#xff1a;我是夜阑的狗&#x1f436; &#x1f680; 个人简介&#xff1a;一个正在努力学技术的CV工程师&#xff0c;专注基础和实战分享 &#xff0c;欢迎咨询&#xff01; &…