目录
组合数据类型
1 列表
列表的表达
列表的性质
列表的操作符
列表的操作方法
2 元组
 元组的表达
元组的操作
元组的常见用处
3 字典
字典的表达
字典的性质
字典的操作方法
4 集合
集合的表达
集合的运算
 集合的操作方法
首页 后端开发 Python教程 Python的组合数据类型怎么用

Python的组合数据类型怎么用

May 11, 2023 pm 12:10 PM
python

组合数据类型

1 列表

列表的表达
  • 序列类型:内部元素有位置关系,能通过位置序号访问其中元素

  • 列表是一个可以使用多种类型元素,支持元素的增、删、查、改操作的序列类型

ls = ["Python", 1989, True, {"version": 3.7}]
ls
登录后复制
['Python', 1989, True, {'version': 3.7}]
登录后复制
  • 另一种产生方式:list(可迭代对象)

  • 可迭代对象包括:字符串、元组、集合、range()等

字符串转列表

list("欢迎订阅本专栏")
登录后复制
['欢', '迎', '订', '阅', '本', '专', '栏']
登录后复制

元组转列表

list(("我", "们", "很", "像"))
登录后复制
['我', '们', '很', '像']
登录后复制

集合转列表

list({"李雷", "韩梅梅", "Jim", "Green"})
登录后复制
['Green', 'Jim', '李雷', '韩梅梅']
登录后复制

特殊的range()

for i in [0, 1, 2, 3, 4, 5]:
    print(i)
登录后复制
0
1
2
3
4
5
登录后复制
登录后复制
for i in range(6):
    print(i)
登录后复制
0
1
2
3
4
5
登录后复制
登录后复制
  • range(起始数字,中止数字,数字间隔)

如果起始数字缺省,默认为0

必须包含中止数字,但是注意中止的数字取不到

数字间隔缺省,默认为1

for i in range(1, 11, 2):
    print(i)
登录后复制
1
3
5
7
9
登录后复制
  • range()转列表

list(range(1, 11, 2))
登录后复制
[1, 3, 5, 7, 9]
登录后复制

列表的性质

  • 列表的长度——len(列表)

ls = [1, 2, 3, 4, 5]
len(ls)
登录后复制
5
登录后复制
  • 列表的索引——与同为序列类型的字符串完全相同

变量名[位置编号]

正向索引从0开始
反向索引从-1开始

cars = ["BYD", "BMW", "AUDI", "TOYOTA"]
登录后复制
登录后复制
登录后复制
print(cars[0])
print(cars[-4])
登录后复制
BYD
BYD
登录后复制
  • 列表的切片

变量名[开始位置:结束位置:切片间隔]

cars = ["BYD", "BMW", "AUDI", "TOYOTA"]
登录后复制
登录后复制
登录后复制
  • 正向切片

print(cars[:3])     # 前三个元素,开始位置缺省,默认为0;切片间隔缺省,默认为1
登录后复制
['BYD', 'BMW', 'AUDI']
登录后复制
print(cars[1:4:2])  # 第二个到第四个元素 前后索引差为2
登录后复制
['BMW', 'TOYOTA']
登录后复制
print(cars[:])      # 获取整个列表,结束位置缺省,默认取值到最后
登录后复制
['BYD', 'BMW', 'AUDI', 'TOYOTA']
登录后复制
print(cars[-4:-2])  # 获取前两个元素
登录后复制
['BYD', 'BMW']
登录后复制
  • 反向切片

cars = ["BYD", "BMW", "AUDI", "TOYOTA"]
登录后复制
登录后复制
登录后复制
print(cars[:-4:-1])      # 开始位置缺省,默认为-1
print(cars[::-1])        # 获得反向列表
登录后复制
['TOYOTA', 'AUDI', 'BMW']
['TOYOTA', 'AUDI', 'BMW', 'BYD']
登录后复制
列表的操作符
  • 用** list1+lis2 **的形式实现列表的拼接

a = [1, 2]
b = [3, 4]
a+b            # 该用法用的不多
登录后复制
[1, 2, 3, 4]
登录后复制
  • 用 n*list 或 list*n 实现列表的成倍复制

初始化列表的一种方式

[0]*10
登录后复制
[0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
登录后复制
列表的操作方法

1、增加元素

  • 在末尾增加元素——列表.append(待增元素)

languages = ["Python", "C++", "R"]
登录后复制
languages.append("Java")
languages
登录后复制
['Python', 'C++', 'R', 'Java']
登录后复制
登录后复制
登录后复制
  • 在任意位置插入元素——列表.insert(位置编号,待增元素)
    在位置编号相应元素插入待增元素

languages.insert(1, "C")
languages
登录后复制
['Python', 'C', 'C++', 'R', 'Java']
登录后复制
  • 在末尾整体并入另一列表——列表1.extend(列表2)

append 将列表2整体作为一个元素添加到列表1中

languages.append(["Ruby", "PHP"])
languages
登录后复制
['Python', 'C', 'C++', 'R', 'Java', ['Ruby', 'PHP']]
登录后复制

extend 将待列表2内的元素逐个添加到列表1中,当然也可以采用加法实现。

languages = ['Python', 'C', 'C++', 'R', 'Java']
languages.extend(["Ruby", "PHP"])
languages
登录后复制
['Python', 'C', 'C++', 'R', 'Java', 'Ruby', 'PHP']
登录后复制

2、删除元素

  • 删除列表i位置的元素  列表.pop(位置)

languages = ['Python', 'C', 'C++', 'R', 'Java']
languages.pop(1)
languages
登录后复制
['Python', 'C++', 'R', 'Java']
登录后复制
登录后复制
登录后复制
  • 不写位置信息,默认删除最后一个元素

languages.pop()
languages
登录后复制
['Python', 'C++', 'R']
登录后复制
  • 删除列表中的第一次出现的待删元素 列表.remove(待删元素)

languages = ['Python', 'C', 'R', 'C', 'Java']
languages.remove("C")    
languages
登录后复制
['Python', 'R', 'C', 'Java']
登录后复制
languages = ['Python', 'C', 'R', 'C', 'Java']
while "C" in languages:
    languages.remove("C")    
languages
登录后复制
['Python', 'R', 'Java']
登录后复制

3、查找元素

  • 列表中第一次出现待查元素的位置 列表.index(待查元素)

languages = ['Python', 'C', 'R','Java']
idx = languages.index("R") 
idx
登录后复制
2
登录后复制

4、修改元素

  • 通过"先索引后赋值"的方式,对元素进行修改 列表名[位置]=新值

languages = ['Python', 'C', 'R','Java']
languages[1] = "C++"
languages
登录后复制
['Python', 'C++', 'R', 'Java']
登录后复制
登录后复制
登录后复制

5、列表的复制

  • 错误的方式:这种方式仅是相当于给列表起了一个别名

languages = ['Python', 'C', 'R','Java']
languages_2 = languages
print(languages_2)
登录后复制
['Python', 'C', 'R', 'Java']
登录后复制
languages.pop()
print(languages)
print(languages_2)
登录后复制
['Python', 'C', 'R']
['Python', 'C', 'R']
登录后复制
  • 正确的方式——浅拷贝

当内容中也有列表这种可变的情况时,这时浅拷贝可能出问题,应该采用深拷贝。

  • 方法1:列表.copy()

languages = ['Python', 'C', 'R','Java']
languages_2 = languages.copy()
languages.pop()
print(languages)
print(languages_2)
登录后复制
['Python', 'C', 'R']
['Python', 'C', 'R', 'Java']
登录后复制
登录后复制
  • 方法2:列表 [ : ]

  • 相当于对整个列表的切片

languages = ['Python', 'C', 'R','Java']
languages_3 = languages[:]
languages.pop()
print(languages)
print(languages_3)
登录后复制
['Python', 'C', 'R']
['Python', 'C', 'R', 'Java']
登录后复制
登录后复制

6、列表的排序

  • 使用列表.sort()对列表进行永久排序

  • 直接在列表上进行操作,无返回值

  • 默认是递增的排序

ls = [2, 5, 2, 8, 19, 3, 7]
ls.sort()
ls
登录后复制
[2, 2, 3, 5, 7, 8, 19]
登录后复制
  • 递减排列

ls.sort(reverse = True)
ls
登录后复制
[19, 8, 7, 5, 3, 2, 2]
登录后复制
登录后复制
  • 使用sorted(列表)对列表进行临时排序

  • 原列表保持不变,返回排序后的列表

ls = [2, 5, 2, 8, 19, 3, 7]
ls_2 = sorted(ls)
print(ls)
print(ls_2)
登录后复制
[2, 5, 2, 8, 19, 3, 7]
[19, 8, 7, 5, 3, 2, 2]
登录后复制
sorted(ls, reverse = True)
登录后复制
[19, 8, 7, 5, 3, 2, 2]
登录后复制
登录后复制

7、列表的翻转

  • 使用列表.reverse()对列表进行永久翻转

  • 直接在列表上进行操作,无返回值

ls = [1, 2, 3, 4, 5]
print(ls[::-1])
ls
登录后复制
[5, 4, 3, 2, 1]

[1, 2, 3, 4, 5]
登录后复制
ls.reverse()
ls
登录后复制
[5, 4, 3, 2, 1]
登录后复制

8、使用for循环对列表进行遍历

ls = [1, 2, 3, 4, 5]
for i in ls:
    print(i)
登录后复制
1
2
3
4
5
登录后复制

2 元组

 元组的表达
  • 元组是一个可以使用多种类型元素,一旦定义,内部元素不支持增、删和修改操作的序列类型

通俗的讲,可以将元组视作“不可变的列表”

names = ("Peter", "Pual", "Mary")
登录后复制
元组的操作
  • 不支持元素增加、元素删除、元素修改操作

  • 其他操作与列表的操作完全一致

元组的常见用处

打包与解包

  • 例1 返回值是打包成元组的形式

def f1(x):              # 返回x的平方和立方
    return x**2, x**3   # 实现打包返回

print(f1(3))
print(type(f1(3)))      # 元组类型
登录后复制
(9, 27)
<class &#39;tuple&#39;>
登录后复制
a, b = f1(3)            # 实现解包赋值 
print(a)
print(b)
登录后复制
9
27
登录后复制
  • 例2

  • 采用zip函数进行打包

numbers = [201901, 201902, 201903]
name = ["小明", "小红", "小强"]
list(zip(numbers,name))
登录后复制
[(201901, '小明'), (201902, '小红'), (201903, '小强')]
登录后复制
for number,name in zip(numbers,name):   # 每次取到一个元组,立刻进行解包赋值
    print(number, name)
登录后复制
201901 小明
201902 小红
201903 小强
登录后复制

3 字典

字典的表达
  • 映射类型: 通过“键”-“值”的映射实现数据存储和查找

  • 常规的字典是无序的,仅可以通过键来对数据进行访问

students = {201901: '小明', 201902: '小红', 201903: '小强'}
students
登录后复制

字典键的要求

  • 1、字典的键不能重复

如果重复,前面的键就被覆盖了

students = {201901: '小明', 201901: '小红', 201903: '小强'}
students
登录后复制
{201901: '小红', 201903: '小强'}
登录后复制
  • 2、字典的键必须是不可变类型,如果键可变,就找不到对应存储的值了

  • 不可变类型:数字、字符串、元组。  一旦确定,它自己就是它自己,变了就不是它了。

  • 可变类型:列表、字典、集合。  一旦确定,还可以随意增删改。因此这三个类型不能作为字典的键。

d1 = {1: 3}
d2 = {"s": 3}
d3 = {(1,2,3): 3}
登录后复制

上面没有报错,说明是合法的。

d = {[1, 2]: 3}
登录后复制
---------------------------------------------------------------------------

TypeError                                 Traceback (most recent call last)

<ipython-input-68-bf7f06622b3f> in <module>
----> 1 d = {[1, 2]: 3}


TypeError: unhashable type: 'list'
登录后复制
d = {{1:2}: 3}
登录后复制
---------------------------------------------------------------------------

TypeError                                 Traceback (most recent call last)

<ipython-input-69-188e5512b5fe> in <module>
----> 1 d = {{1:2}: 3}


TypeError: unhashable type: 'dict'
登录后复制
d = {{1, 2}: 3}
登录后复制
---------------------------------------------------------------------------

TypeError                                 Traceback (most recent call last)

<ipython-input-70-c2dfafc1018a> in <module>
----> 1 d = {{1, 2}: 3}


TypeError: unhashable type: 'set'
登录后复制
字典的性质
  • 字典的长度——键值对的个数

students = {201901: '小明', 201902: '小红', 201903: '小强'}
len(students)
登录后复制
3
登录后复制
登录后复制
  • 字典的索引

通过 字典[键] 的形式来获取对应的值

students = {201901: '小明', 201902: '小红', 201903: '小强'}
students[201902]
登录后复制
'小红'
登录后复制
字典的操作方法

1、增加键值对

  • 变量名[新键] = 新值

students = {201901: '小明', 201902: '小红', 201903: '小强'}
students[201904] = "小雪"
students
登录后复制
{201901: '小明', 201902: '小红', 201903: '小强', 201904: '小雪'}
登录后复制

2、删除键值对

  • 通过del 变量名[待删除键]

students = {201901: '小明', 201902: '小红', 201903: '小强'}
del students[201903]
students
登录后复制
{201901: '小明', 201902: '小红'}
登录后复制
  • 通过变量名.pop(待删除键)

students = {201901: '小明', 201902: '小红', 201903: '小强'}
value = students.pop(201903)   # 删除键值对,同时获得删除键值对的值
print(value)
print(students)
登录后复制
小强
{201901: '小明', 201902: '小红'}
登录后复制
  • 变量名.popitem() 随机删除一个键值对,并以元组返回删除键值对

students = {201901: '小明', 201902: '小红', 201903: '小强'}
key, value = students.popitem()
print(key, value)
print(students)
登录后复制
201903 小强
{201901: '小明', 201902: '小红'}
登录后复制

3、修改值

  • 通过先索引后赋值的方式对相应的值进行修改

students = {201901: '小明', 201902: '小红', 201903: '小强'}
students[201902] = "小雪"
students
登录后复制
{201901: '小明', 201902: '小雪', 201903: '小强'}
登录后复制

4、d.get( )方法

d.get(key,default) 从字典d中获取键key对应的值,如果没有这个键,则返回default

  • 小例子:统计"牛奶奶找刘奶奶买牛奶"中字符的出现频率

s = "牛奶奶找刘奶奶买牛奶"
d = {}
print(d)
for i in s:
    d[i] = d.get(i, 0)+1 # 如果该字符第一次出现,则返回default 0 ,然后+1统计。如果之前就有i这个键,则返回该 key i 所对应的值。
    print(d)
# print(d)
登录后复制
{}
{'牛': 1}
{'牛': 1, '奶': 1}
{'牛': 1, '奶': 2}
{'牛': 1, '奶': 2, '找': 1}
{'牛': 1, '奶': 2, '找': 1, '刘': 1}
{'牛': 1, '奶': 3, '找': 1, '刘': 1}
{'牛': 1, '奶': 4, '找': 1, '刘': 1}
{'牛': 1, '奶': 4, '找': 1, '刘': 1, '买': 1}
{'牛': 2, '奶': 4, '找': 1, '刘': 1, '买': 1}
{'牛': 2, '奶': 5, '找': 1, '刘': 1, '买': 1}
登录后复制

5、d.keys( ) d.values( )方法

把所有的key,value 单独拿出来。

students = {201901: '小明', 201902: '小红', 201903: '小强'}
print(list(students.keys()))
print(list(students.values()))
登录后复制
[201901, 201902, 201903]
['小明', '小红', '小强']
登录后复制

6、d.items( )方法及字典的遍历

print(list(students.items()))
for k, v in students.items():#进行解包
    print(k, v)
登录后复制
[(201901, '小明'), (201902, '小红'), (201903, '小强')]
201901 小明
201902 小红
201903 小强
登录后复制

4 集合

集合的表达

  • 一系列互不相等元素的无序集合(互斥)

  • 元素必须是不可变类型:数字,字符串或元组,可视作字典的键

  • 可以看做是没有值,或者值为None的字典

students = {"小明", "小红", "小强", "小明"}   #可用于去重
students
登录后复制
{'小强', '小明', '小红'}
登录后复制
集合的运算
  • 小例子 通过集合进行交集并集的运算

Chinese_A = {"刘德华", "张学友", "张曼玉", "钟楚红", "古天乐", "林青霞"}
Chinese_A
登录后复制
{'刘德华', '古天乐', '张学友', '张曼玉', '林青霞', '钟楚红'}
登录后复制
Math_A = {"林青霞", "郭富城", "王祖贤", "刘德华", "张曼玉", "黎明"}
Math_A
登录后复制
{'刘德华', '张曼玉', '林青霞', '王祖贤', '郭富城', '黎明'}
登录后复制
  • 语文和数学两门均为A的学员

  • S & T 返回一个新集合,包括同时在集合S和T中的元素

Chinese_A & Math_A
登录后复制
{'刘德华', '张曼玉', '林青霞'}
登录后复制
  • 语文或数学至少一门为A的学员

  • S | T 返回一个新集合,包括集合S和T中的所有元素

Chinese_A | Math_A
登录后复制
{'刘德华', '古天乐', '张学友', '张曼玉', '林青霞', '王祖贤', '郭富城', '钟楚红', '黎明'}
登录后复制
  • 语文数学只有一门为A的学员

  • S ^ T 返回一个新集合,包括集合S和T中的非共同元素

Chinese_A ^ Math_A
登录后复制
{'古天乐', '张学友', '王祖贤', '郭富城', '钟楚红', '黎明'}
登录后复制
  • 语文为A,数学不为A的学员

  • S - T 返回一个新集合,包括在集合S但不在集合T中的元素

Chinese_A - Math_A
登录后复制
{'古天乐', '张学友', '钟楚红'}
登录后复制
  • 数学为A,语文不为A的学员

Math_A - Chinese_A
登录后复制
{'王祖贤', '郭富城', '黎明'}
登录后复制
 集合的操作方法
  • 增加元素——S.add(x)

stars = {"刘德华", "张学友", "张曼玉"}
stars.add("王祖贤")
stars
登录后复制
{'刘德华', '张学友', '张曼玉', '王祖贤'}
登录后复制
  • 移除元素——S.remove(x)

stars.remove("王祖贤")
stars
登录后复制
{'刘德华', '张学友', '张曼玉'}
登录后复制
  • 集合的长度——len(S)

len(stars)
登录后复制
3
登录后复制
登录后复制
  • 集合的遍历——借助for循环

for star in stars:
    print(star)
登录后复制
张学友
张曼玉
刘德华
登录后复制

以上是Python的组合数据类型怎么用的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP和Python:比较两种流行的编程语言 PHP和Python:比较两种流行的编程语言 Apr 14, 2025 am 12:13 AM

PHP和Python各有优势,选择依据项目需求。1.PHP适合web开发,尤其快速开发和维护网站。2.Python适用于数据科学、机器学习和人工智能,语法简洁,适合初学者。

Python:游戏,Guis等 Python:游戏,Guis等 Apr 13, 2025 am 12:14 AM

Python在游戏和GUI开发中表现出色。1)游戏开发使用Pygame,提供绘图、音频等功能,适合创建2D游戏。2)GUI开发可选择Tkinter或PyQt,Tkinter简单易用,PyQt功能丰富,适合专业开发。

debian readdir如何与其他工具集成 debian readdir如何与其他工具集成 Apr 13, 2025 am 09:42 AM

Debian系统中的readdir函数是用于读取目录内容的系统调用,常用于C语言编程。本文将介绍如何将readdir与其他工具集成,以增强其功能。方法一:C语言程序与管道结合首先,编写一个C程序调用readdir函数并输出结果:#include#include#includeintmain(intargc,char*argv[]){DIR*dir;structdirent*entry;if(argc!=2){

Python和时间:充分利用您的学习时间 Python和时间:充分利用您的学习时间 Apr 14, 2025 am 12:02 AM

要在有限的时间内最大化学习Python的效率,可以使用Python的datetime、time和schedule模块。1.datetime模块用于记录和规划学习时间。2.time模块帮助设置学习和休息时间。3.schedule模块自动化安排每周学习任务。

Nginx SSL证书更新Debian教程 Nginx SSL证书更新Debian教程 Apr 13, 2025 am 07:21 AM

本文将指导您如何在Debian系统上更新NginxSSL证书。第一步:安装Certbot首先,请确保您的系统已安装certbot和python3-certbot-nginx包。若未安装,请执行以下命令:sudoapt-getupdatesudoapt-getinstallcertbotpython3-certbot-nginx第二步:获取并配置证书使用certbot命令获取Let'sEncrypt证书并配置Nginx:sudocertbot--nginx按照提示选

Debian OpenSSL如何配置HTTPS服务器 Debian OpenSSL如何配置HTTPS服务器 Apr 13, 2025 am 11:03 AM

在Debian系统上配置HTTPS服务器涉及几个步骤,包括安装必要的软件、生成SSL证书、配置Web服务器(如Apache或Nginx)以使用SSL证书。以下是一个基本的指南,假设你使用的是ApacheWeb服务器。1.安装必要的软件首先,确保你的系统是最新的,并安装Apache和OpenSSL:sudoaptupdatesudoaptupgradesudoaptinsta

Debian上GitLab的插件开发指南 Debian上GitLab的插件开发指南 Apr 13, 2025 am 08:24 AM

在Debian上开发GitLab插件需要一些特定的步骤和知识。以下是一个基本的指南,帮助你开始这个过程。安装GitLab首先,你需要在Debian系统上安装GitLab。可以参考GitLab的官方安装手册。获取API访问令牌在进行API集成之前,首先需要获取GitLab的API访问令牌。打开GitLab仪表盘,在用户设置中找到“AccessTokens”选项,生成一个新的访问令牌。将生成的

apache属于什么服务 apache属于什么服务 Apr 13, 2025 pm 12:06 PM

Apache是互联网幕后的英雄,不仅是Web服务器,更是一个支持巨大流量、提供动态内容的强大平台。它通过模块化设计提供极高的灵活性,可根据需要扩展各种功能。然而,模块化也带来配置和性能方面的挑战,需要谨慎管理。Apache适合需要高度可定制、满足复杂需求的服务器场景。

See all articles