脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|shell|

服务器之家 - 脚本之家 - Python - Python中的复杂数据类型(list、tuple)

Python中的复杂数据类型(list、tuple)

2023-02-20 11:49springsnow Python

这篇文章介绍了Python中的复杂数据类型(list、tuple),文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

一、序列:

序列是基类类型,序列扩展类型包括:字符串、元组和列表

Python中的复杂数据类型(list、tuple)

序列都可以进行的操作包括索引,切片,加,乘,检查成员。

此外,Python已经内置确定序列的长度以及确定最大和最小的元素的方法。

二、列表(list):[a1,a2],可变数据类型

列表:列表是序列类型的一种扩展,十分常用

1、列表的创建

  • 列表是一种序列类型,创建后可以随意被修改
  • 使用方括号 [] 或list() 创建,元素间用逗号 , 分隔
  • 列表中各元素类型可以不同,无长度限制
?
1
2
3
4
5
hobby_list = [hobby, 'run', 'girl']
 
print(id(hobby_list)) # 4558605960
print(type(hobby_list)) #
print(hobby_list) # ['read', 'run', 'girl']

如果想初始化个长度为10的列表

?
1
2
3
list_empty = [None]*10
print(list_empty)
# [None, None, None, None, None, None, None, None, None, None]

使用range()函数来创建一个列表:

?
1
2
hobby_list = list(range(5))
# [0, 1, 2, 3, 4]

2、复合列表和多维列表

?
1
2
hobby_list = ['read', 'run',['girl_name', 18, 'shanghai'] ]
print(hobby_list[2][1])#  取出girl的年龄 18

python 创建二维列表,将需要的参数写入 cols 和 rows 即可

?
1
2
3
4
5
6
list_2d = [[0 for i in range(5)] for i in range(5)]
list_2d[0].append(3)
list_2d[0].append(5)
list_2d[2].append(7)
print(list_2d)
# [[0, 0, 0, 0, 0, 3, 5], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0, 7], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0]]

以下实例将3X4的矩阵列表转换为4X3列表:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# 以下实例展示了3X4的矩阵列表:
matrix = [
    [1, 2, 3, 4],
    [5, 6, 7, 8],
    [9, 10, 11, 12],
]
 
# 以下实例将3X4的矩阵列表转换为4X3列表:
transposed=[[row[i] for row in matrix] for i in range(4)]
print(transposed)
# [[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]
 
# 以下实例也可以使用以下方法来实现:
transposed = []
for i in range(4):
    transposed.append([row[i] for row in matrix])
print(transposed)
# [[1, 5, 9], [2, 6, 10], [3, 7, 11], [4, 8, 12]]

3、列表索引取值

索引序号从0开始。

?
1
2
3
4
hobby_list = ['read', 'run', 'girl']
# 索引序号      0       1      2
 
print(hobby_list[1])#  取出第二个爱好 <code>run

4、列表修改

可以对列表的数据项进行修改或更新,你也可以使用append()方法来添加列表项,

?
1
2
hobby_list = ['read', 'run', 'girl']
hobby_list[0] = 'write'

列表方法使得列表可以很方便的作为一个堆栈来使用。堆栈作为特定的数据结构,最先进入的元素最后一个被释放(后进先出)。

用 append() 方法可以把一个元素添加到堆栈顶。用不指定索引的 pop() 方法可以把一个元素从堆栈顶释放出来。

  • append:在列表ls最后增加一个元素x
  • pop():移除列表中的一个元素(默认最后一个元素),并且返回该元素的值

例如:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
stack = [3, 4, 5]
stack.append(6)
stack.append(7)
print(stack)
# [3, 4, 5, 6, 7]
 
print(stack.pop())
# 7
print(stack)
# [3, 4, 5, 6]
print(stack.pop())
# 6
print(stack.pop())
# 5
 
print(stack)
# [3, 4]

三、列表推导式

列表推导式提供了从序列创建列表的简单途径。通常应用程序将一些操作应用于某个序列的每个元素,用其获得的结果作为生成新列表的元素,或者根据确定的判定条件创建子序列。

每个列表推导式都在 for 之后跟一个表达式,然后有零到多个 for 或 if 子句。

返回结果是一个根据表达从其后的 for 和 if 上下文环境中生成出来的列表。如果希望表达式推导出一个元组,就必须使用括号。

1、列表推导式书写形式:

  • [表达式 for 变量 in 列表]
  • [表达式 for 变量 in 列表 if 条件]

举例:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
print([i for i in range(10)] )  # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
print([i ** 2 for i in range(10)])  # [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
  
print([0 for i in range(5)])  #[0, 0, 0, 0, 0]
 
name_list = ['nick', 'sean', 'jason', 'tank']
for n in [name if name == 'nick' else name + '_a' for name in name_list] :
    print(n)  # 'nick', 'sean_a', 'jason_a', 'tank_a'
 
li = [1, 2, 3, 4, 5, 6, 7, 8, 9]
print( [x ** 2 for x in li]) # [1, 4, 9, 16, 25, 36, 49, 64, 81]
print( [x ** 2 for x in li if x > 5]) # [36, 49, 64, 81]
print(dict([(x, x * 10) for x in li])) # {1: 10, 2: 20, 3: 30, 4: 40, 5: 50, 6: 60, 7: 70, 8: 80, 9: 90} #生成字典
 
vec1 = [2, 4, 6]
vec2 = [4, 3, -9]
sq = [vec2[i] + vec2[i] for i in range(len(vec))]  # 实现列表相加
print(sq)
# [6, 7, -3]
 
testList = [1, 2, 3, 4]
 
def mul2(x):
    return x * 2
 
 
print([mul2(i) for i in testList]) #使用复杂表达式或嵌套函数:
# [2, 4, 6, 8]

2、列表推导式的嵌套

语句之间是嵌套关系。

左边第二个语句是最外层,依次往右进一层,左边第一条语句是最后一层。

?
1
[x*y for x in range(1,5) if x > 2 for y in range(1,4) if y < 3]

他的执行顺序是:

?
1
2
3
4
5
for x in range(1,5)
    if x > 2
        for y in range(1,4)
            if y < 3
                x*y

实例

?
1
2
3
4
5
print( [ (x, y) for x in range(10) if x % 2 if x > 3 for y in range(10) if y > 7 if y != 8]) #生成元组
# [(5, 9), (7, 9), (9, 9)]
 
print([x * y for x in [1, 2, 3] for y in [1, 2, 3]])
# [1, 2, 3, 2, 4, 6, 3, 6, 9]

四、列表的基本操作

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
ls1 = ['python', 123]
ls2 = ['java', 456]
print(ls1 * 2);  # ['python', 123, 'python', 123] 将列表复制n次。
print(ls1 + ls2);  # ['python', 123, 'java', 456] 连接两个列表
 
name_list = ['nick', 'jason', 'tank', 'sean']
del name_list[2# 删除索引2位置后的元素
print(name_list)  # ['nick', 'jason', 'sean']
 
del name_list[2:4] # 从列表中删除切片 ,删除第i-j位置的元素
print(name_list)  # ['nick', 'jason']
 
del name_list[:] #清空整个列表
print(name_list)  # []
del # 用 del 删除实体变量:
 
 
name_list = ['nick', 'jason', 'tank', 'sean']
print('tank sb' in name_list)  #  成员运算:in; False
print('nick handsome' not in name_list)  # 成员运算:in;True
 
 
name_list = ['nick', 'jason', 'tank', 'sean']
for name in name_list:  # for循环
    print(name)
 
 
a = ['Google', 'Baidu', 'Runoob', 'Taobao', 'QQ']
for i in range(len(a)): # 结合range()和len()函数以遍历一个序列的索引
    print(i, a[i])
# 0 Google 1 Baidu 2 Runoob 3 Taobao 4 QQ
 
 
name_list = ['nick', 'jason', 'tank', 'sean']
print(name_list[0:3:2] )  # 切片  ['nick', 'tank']

举例:有如下列表,列表元素为不可hash类型,去重,得到新列表,且新列表一定要保持列表原来的顺序

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
stu_info_list = [
    {'name': 'nick', 'age': 19, 'sex': 'male'},
    {'name': 'egon', 'age': 18, 'sex': 'male'},
    {'name': 'tank', 'age': 20, 'sex': 'female'},
    {'name': 'tank', 'age': 20, 'sex': 'female'},
    {'name': 'egon', 'age': 18, 'sex': 'male'},
]
 
new_stu_info_list = []
for stu_info in stu_info_list:
    if stu_info not in new_stu_info_list:
        new_stu_info_list.append(stu_info)
 
for new_stu_info in new_stu_info_list:
    print(new_stu_info)

五、列表相关函数

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
name_list = ['nick', 'jason', 'tank', 'sean']
print(len(name_list))  # 4 列表元素个数:len;
print(min(name_list))  # jason 返回序列s的最小元素;
print(max(name_list))  # tank 返回序列s的最大元素
 
name_list = ['nick', 'jason', 'tank', 'sean']
name_list.insert(1, 'handsome') # insert(i,x):在列表的第i位置增加元素x
print(name_list)  # ['nick', 'handsome', 'jason', 'tank', 'sean']
 
name_list = ['nick', 'jason', 'tank', 'sean']
print(name_list.remove('nick'))  # remove(x):将列表ls中出现的第一个元素x删除 ,None ;
print(name_list)  # ['jason', 'tank', 'sean']
 
name_list = ['nick', 'jason', 'tank', 'sean']
print(name_list.count('nick'))  # 1  ;统计某个元素在列表中出现的次数
 
name_list = ['nick', 'jason', 'tank', 'sean']
print(name_list.index('nick'))  # 0;返回元素所在列表中的索引
 
name_list = ['nick', 'jason', 'tank', 'sean']
name_list.clear() # 删除列表中所有元素
print(name_list)  # []
 
name_list = ['nick', 'jason', 'tank', 'sean']
print(name_list.copy())  # 生成一个新列表,赋值原列表中所有元素  ['nick', 'jason', 'tank', 'sean']
 
name_list = ['nick', 'jason', 'tank', 'sean']
name_list2 = ['nick handsome']
name_list.extend(name_list2) # 在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)
print(name_list)  # ['nick', 'jason', 'tank', 'sean', 'nick handsome']
 
name_list = ['nick', 'jason', 'tank', 'sean']
name_list.reverse() # 将列表ls中的元素反转
print(name_list)  # ['sean', 'tank', 'jason', 'nick']
 
name_list = ['nick', 'jason', 'tank', 'sean']
name_list.sort() # 排序,使用用sort列表的元素必须是同类型的
 
print(name_list)  # ['jason', 'nick', 'sean', 'tank']
 
name_list.sort(reverse=True) # 倒序
print(name_list)  # ['tank', 'sean', 'nick', 'jason']

六、元组(tuple):(a1,a2)

1、元组的创建

元组是一种列表类型,一旦创建就不能被修改。

?
1
2
3
4
5
color = (0x001100, "blue", creature) # 使用小括号 () 或 tuple() 创建,元素间用逗号分隔。
print(type(color))  #
 
creature = "cat", "dog", "tiger", "human" # 可以使用或不使用小括号。即元组由若干逗号分隔的值组成。
print(type(creature))  #

注意与字符串区别:

?
1
2
3
4
5
name_str = ('egon'# ()只是普通包含的意思
name_tuple = ('egon',)  # 元组中只包含一个元素时,需要在元素后面添加逗号,否则括号会被当作字符串使用:
 
print(type(name_str))  #
print(type(name_tuple))  #

2、元组的操作

索引取值、切片(顾头不顾尾,步长)、长度len、成员运算in和not in、循环、count、index等均同列表,只是不更改值。

元组中的元素值是不允许修改的,但我们可以对元组进行连接组合,如下实例:

?
1
2
3
4
5
6
7
8
9
tup1 = (12, 34.56);
tup2 = ('abc', 'xyz')
 
# 以下修改元组元素操作是非法的。
# tup1[0] = 100
 
# 创建一个新的元组
tup3 = tup1 + tup2;
print(tup3)  # (12, 34.56, 'abc', 'xyz')

3、namedtuple(具名元组): Python元组的升级版本

?
1
2
3
4
5
6
from collections import namedtuple
 
User = namedtuple('User', 'name sex age') # 定义一个namedtuple类型User,并包含name,sex和age属性。
user = User(name='Runoob', sex='male', age=12) # 创建一个User对象
 
print(user.age)  # 12

到此这篇关于Python中的复杂数据类型(list、tuple)的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://www.cnblogs.com/springsnow/p/11944380.html

延伸 · 阅读

精彩推荐
  • Python瞧瞧,这样的代码才叫 Pythonic

    瞧瞧,这样的代码才叫 Pythonic

    要写出 Pythonic(优雅的、地道的、整洁的)代码,还要平时多观察那些大牛代码,这里明哥收集了一些比较常见的 Pythonic 写法,帮助你养成写优秀代码的习惯...

    Python编程时光4392020-10-27
  • Python使用python进行拆分大文件的方法

    使用python进行拆分大文件的方法

    今天小编就为大家分享一篇使用python进行拆分大文件的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    IBoyMan11762021-04-27
  • Python教你使用pyinstaller打包Python教程

    教你使用pyinstaller打包Python教程

    今天带大家学习使用pyinstaller打包Python,文中有非常详细的图文示例及代码,对正在学习python的小伙伴们很有帮助,需要的朋友可以参考下...

    wtzhu_1312012021-11-15
  • PythonPython对象与引用的介绍

    Python对象与引用的介绍

    今天小编就为大家分享一篇关于Python对象与引用的介绍,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看...

    Devin0121311772021-05-21
  • PythonPython学习之时间包使用教程详解

    Python学习之时间包使用教程详解

    本文主要介绍了Python中的内置时间包:datetime包 与 time包 ,通过学习时间包可以让我们的开发过程中对时间进行轻松的处理,快来跟随小编一起学习一下吧...

    渴望力量的哈士奇3622022-11-10
  • PythonPython 使用 consul 做服务发现示例详解

    Python 使用 consul 做服务发现示例详解

    这篇文章主要介绍了Python 使用 consul 做服务发现示例详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考...

    双鬼带单5532021-09-18
  • Pythonpython实现从ftp服务器下载文件的方法

    python实现从ftp服务器下载文件的方法

    这篇文章主要介绍了python实现从ftp服务器下载文件的方法,涉及Python操作FTP的相关技巧,非常具有实用价值,需要的朋友可以参考下 ...

    重负在身8662020-06-18
  • Pythonpyinstaller打包后,配置文件无法正常读取的解决

    pyinstaller打包后,配置文件无法正常读取的解决

    这篇文章主要介绍了pyinstaller打包后,配置文件无法正常读取的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不...

    被污染的一张白纸5862022-09-23