遍历列表-for循环
列表中存储的元素可能非常多,如果想一个一个的访问列表中的元素,可能是一件十分头疼的事。那有没有什么好的办法呢?当然有!使用 for循环
假如有一个食物名单列表,通过 for循环 将列表中的食物名称都打印出来
1
2
3
4
5
|
# 定义一个食物名单列表
foods = [ 'potato' , 'tomato' , 'noodles' , 'apple' , 'pizza' ]
# 循环访问foods列表
for food in foods:
print (food)
|
输出:
potato tomato noodles apple pizza
for循环 将foods列表中的元素依次输出了出来
for food in foods: 这行代码表示将foods列表中的元素依次取出,每次次元素的值赋给变量food;本句代码最后以冒号结尾
print(food) 本行代码之前有四个字符的 缩进 ,表示这行代码属于 for food in foods: 的代码块
for循环每次从列表中取出一个元素后,都会进入代码块中执行一遍,即输出元素的名称;直到将列表所有的元素都遍历一次后,循环停止
1
2
3
4
5
6
7
8
|
# 定义一个食物名单列表
foods = [ 'potato' , 'tomato' , 'noodles' , 'apple' , 'pizza' ]
# 循环访问foods列表
for food in foods:
print (food)
# 循环之外的代码
print ( '循环已经完毕' )
print ( '循环已经完毕' ) 的前面没有缩进,说明它不属于 for 循环块中的代码;所以,当 for 循环完毕后,会接着执行下面的这句代码
|
输出:
potato
tomato
noodles
apple
pizza
循环已经完毕
其中,变量 food 是一个临时变量,可以随意取名称;不过建议取有意义的名称,在这里用foods表示食物列表,用food表示列表中的食物,方便理解
循环也可以嵌套使用
假如小明喜欢一些食物,这些食物名称被存储到foods1列表中;小红喜欢另一些食物,这些食物名称被存储到foods2中;现在想知道小明与小红所喜欢的食物是否有相同的,则可用如下方式:
1
2
3
4
5
6
7
8
9
10
|
# 小明喜欢的食物列表
foods1 = [ 'potato' , 'tomato' , 'noodles' , 'apple' , 'pizza' ]
# 小红喜欢的食物列表
foods2 = [ 'chocolate' , 'pizza' , 'maize' , 'watermelon' ]
# 通嵌套循环寻找出两个列表中相同的食物名称
for food1 in foods1:
for food2 in foods2:
if food1 = = food2:
print ( '小明和小红共同喜欢的食物是' , food1)
|
输出:
小明和小红共同喜欢的食物是 pizza
for food2 in foods2: 前面有缩进,说明它是 for food1 in foods1: 块中的代码;第一外循环从小明喜欢的食物列表中依次取出食物名称,然后进行自身的代码块中;第二行代码依次遍历小红喜欢的食物列表,然后进行循环体(代码块),然后判断foods1中的第一个元素与foods2中的第一个元素是否一样,foods1中的第一个元素与foods2中的第二个元素是否一样,……,foods1中的第一个元素与foods2中的第四个元素是否一样,如果一样,则执行打印 print('小明和小红共同喜欢的食物是', food1) ;接着判断foods1中的第二个元素与foods2中的第1个元素是否一样,……,foods1中的第二个元素与foods2中的第四个元素是否一样,如果一样,则执行打印 print('小明和小红共同喜欢的食物是', food1) ……直到判断到foods1中的第五与foods2的所有元素比较一次后,嵌套循环执行完毕
注: if 表示判断一个结果,如果结果是真,则执行代码块,如果不是真,则跳过代码块; == 表示判断两个值是否相等,如果相等返回真,如果不相等返回假。这两个知识点将在后面进行详细探讨
在写 for 循环语句的时候,造成别忘记在后面加上 冒号 ,循环体中的代码千万别忘记添加缩进;缩进一般是一个制表符的距离,即四个空格的距离;不过,不建议将制表符与空格符混合使用
创建数值列表-range()
前面的列表中的元素都是字符串类型的,列表中可以存储任意对象,现在定义一个数值列表
numbers = [1,2,3,4,5]
如果想定义一个从1到1000的数值列表,手动将这些数值一个一个写进列表里,一点也不高效;可以使用函数 range() 快速创建一系列数字
1
2
|
for value in range ( 1 , 6 ):
print (value)
|
输出:
rnage(1, 6) 会生成从1到5的数字,6表示到6的时候就停止创建动作,如果想创建1到1000的数字,则是 range(1, 1001)
通过 list() 可以将 range() 创建的数字转换成列表
1
2
3
4
5
6
|
# 输出range()看看
numbers = range ( 1 , 6 )
print ( 'range: ' ,numbers)
# 转换成列表后,再输出看看
numbers = list (numbers)
print ( 'list: ' ,numbers)
|
输出:
range: range(1, 6) list: [1, 2, 3, 4, 5]
可以看出, range() 返回的是一个 可迭代对象 ,经过转换后才是一个列表对象
还可以通过指定 步长 ,来生成一系列偶数
1
2
|
numbers = range ( 2 , 21 , 2 )
print ( list (numbers))
|
输出:
[2, 4, 6, 8, 10, 12, 14, 16, 18, 20]
range(start, stop[, step]) 这是Python的使用说明文档中关于 range() 的使用说明,start表示从哪个数字开始,stop表示到哪个数字停止,[, step]表示步长,方括号表示这个参数是可选的,即可写可不写
可以在Python的IDLE中输入 help(range) 来得到关于range()的帮助文档
>>> help(range)
一些简单的、常用的数字列表统计函数:
1
2
3
4
5
6
7
8
9
|
# 定义一个偶数列表
numbers = list ( range ( 2 , 21 , 2 ))
# 求数值列表中最小的元素值
print ( min (numbers))
# 求数值列表中最大的元素值
print ( max (numbers))
# 求数值列表所有元素的和
print ( sum (numbers))
|
输出:
列表解析
直接看下面代码
1
2
3
4
|
# 定义一个偶数列表
numbers = list ( range ( 2 , 21 , 2 ))
squares = [value * * 2 for value in numbers]
print (squares)
|
输出:
[4, 16, 36, 64, 100, 144, 196, 256, 324, 400]
for循环的这种写法 squares = [value**2 for value in numbers]
叫做 列表解析
首先,写一对中括号,它表示一个列表;然后列表中分类两部分,第一个部分是表达式,即 value**2 ,这个表达的意思是计算一个值的乘方;第二部分是列表循环,即 for value in numbers ;最终结果是将列表中的每个值都按乘方计算一次后,放入一个列表中,再赋值给变量 squares
这里需要注意的是,循环后面没有冒号,可以理解为将循环体的代码块精简成了一个表达式
列表切片
只获取列表的部分元素,这样的操作叫作 切片
切片通过列表的索引进行操作,即从哪个索引开始,到哪个索引结果,将这段元素取出
1
2
3
4
5
|
# 定义一个食物列表
foods = [ 'potato' , 'tomato' , 'noodles' , 'apple' , 'pizza' ]
# 取出第二个元素到第四个元素
print (foods[ 1 : 4 ])
|
输出:
['tomato', 'noodles', 'apple']
foods[1:4] 方括号中的1表示索引1位置,4表示索引4位置;需要注意的是,1表示从索引1开始,而4表示到索引4就结束;也就说,索引4位置的元素不会返回;所以,这里返回的结果是从索引1到索引3的三个元素
如果省略冒号前的数字,则表示从开始的位置取值
1
2
3
4
5
6
7
8
|
# 从索引0开始,取到索引4之前的所有值
foods[: 4 ]
如果省略冒号后的数字,则表示一直取到列表的末尾
# 从索引1开始,一下取到列表结束的位置
foods[ 1 :]
如果只有冒号,表示取所有数据
# 取所有数据
foods[:]
|
还可能使用负数
# 从倒数3个元素开始,一直取到末尾
foods[-3:]
for循环与切片的结合
1
2
3
4
5
|
# 定义一个食物列表
foods = [ 'potato' , 'tomato' , 'noodles' , 'apple' , 'pizza' ]
# 打印第2个到第4个元素
for food in foods[ 1 : 4 ]:
print (food)
|
输出:
tomato noodles apple
关于列表的复制
先来看个例子
1
2
3
4
|
foods1 = [ 'potato' , 'tomato' , 'noodles' , 'apple' , 'pizza' ]
foods2 = foods1
print (foods1)
print (foods2)
|
将foods1列表赋值给foods2列表,看似是一个复制动作,但foods1与foods2实际上是一个对象
1
2
3
4
5
|
foods1 = [ 'potato' , 'tomato' , 'noodles' , 'apple' , 'pizza' ]
foods2 = foods1
foods1.append( 'chocolate' )
print (foods1)
print (foods2)
|
输出结果:
['potato', 'tomato', 'noodles', 'apple', 'pizza', 'chocolate'] ['potato', 'tomato', 'noodles', 'apple', 'pizza', 'chocolate']
因为, ['potato', 'tomato', 'noodles', 'apple', 'pizza'] 创建了一个列表对象,foods1变量与foods2变量实际存储的是指向 ['potato', 'tomato', 'noodles', 'apple', 'pizza'] 的一个引用,所以,修改foods1后,发现food2也变了
复制需要另外创建出一个一模一样的对象出来,但它们必须的确是两个对象才行
1
2
3
4
5
|
foods1 = [ 'potato' , 'tomato' , 'noodles' , 'apple' , 'pizza' ]
foods2 = foods1[:]
foods1.append( 'chocolate' )
print (foods1)
print (foods2)
|
输出:
['potato', 'tomato', 'noodles', 'apple', 'pizza', 'chocolate'] ['potato', 'tomato', 'noodles', 'apple', 'pizza']
foods1[:] 返回foods1所有的元素,并创建了一个副本,这个副本是另一个对象,然后再会给了foods2,因此在更改foods1时,没有影响到副本
也可以使用 id(foods1);id(foods2) 来查看列表对象在计算机内的ID,ID不同,则不是同一个对象
简单谈一下元组
元组的使用与列表类似,不同的,列表是可改变的,而元组不是可改变的;列表用 [] 来定义,元组则使用 () 来定义
1
2
3
4
5
6
7
8
9
|
# 定义一个元组
numbers = ( 1 , 2 , 3 , 4 , 5 )
# 支持索引访问
print (numbers[ 1 ])
# 支持循环
for number in numbers:
print (number)
# 不支持对元素的修改,执行下面代码会报错
numbers[ 0 ] = 11
|
报错内容
Traceback (most recent call last): File "C:/Users/Administrator/Desktop/s.py", line 11, in <module> numbers[0] = 11 TypeError: 'tuple' object does not support item assignment
下面看一段示例代码the day of python learning(列表)
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
|
列表是python中的基础数据类型之一,其他语言中也有类似于列表的数据类型,比如js中叫数组,他是以[]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型比如:
li = [‘alex ',123,Ture,(1,2,3,' wusir '),[1,2,3,' 小明 ',],{‘name' : 'alex' }]
列表相比于字符串,不仅可以储存不同的数据类型,而且可以储存大量数据, 32 位python的限制是 536870912 个元素, 64 位python的限制是 1152921504606846975 个元素。而且列表是有序的,有索引值,可切片,方便取值。
# li = ['alex',[1,2,3],'wusir','egon','女神','taibai']
# l1 = li[0]
# print(l1) #“alex‘
# l2 = li[1] #[1,2,3]
# print(l2)
# l3 = li[0:3] #['alex', [1, 2, 3], 'wusir']
# print(l3)
li = [ 'alex' , 'wusir' , 'egon' , '女神' , 'taibai' ]
#增加 append() insert()
# li.append('日天')
# li.append(1)
# print(li)
# while 1:
# username = input('>>>')
# if username.strip().upper() == 'Q':
# break
# else:
# li.append(username)
# print(li)
# li.insert(4,'春哥')
# print(li)
# li.extend('二哥')
# li.extend([1,2,3])
# print(li)
#删
li = [ 'taibai' , 'alex' , 'wusir' , 'egon' , '女神' ,]
# name = li.pop(1) # 返回值
# name = li.pop() # 默认删除最后一个
# print(name,li)
# li.remove('taibai') # 按元素去删除
# print(li)
# li.clear() # 清空
# print(li)
# del li
# del li[0:2] # 切片去删除
# print(li)
#改
# li[0] = '男兽'
# li[0] = [1,2,3]
#切片
# li[0:3] = '云姐plfdslkmgdfjglk'
# li[0:3] = [1,2,3,'春哥','咸鱼哥']
# print(li)
#查
# for i in li:
# print(i)
# print(li[0:2])
#公共方法:
# l = len(li)
# print(l)
# num = li.count('taibai')
# print(num)
# print(li.index('wusir'))
# li = [1,5,4,7,6,2,3]
# #正向排序
# # li.sort()
# # print(li)
# #反向排序
# # li.sort(reverse=True)
# # print(li)
# #反转
# li.reverse()
# print(li)
#列表的嵌套
li = [ 'taibai' , '武藤兰' , '苑昊' ,[ 'alex' , 'egon' , 89 ], 23 ]
# print(li[1][1])
# name = li[0].capitalize()
# # print(name)
# li[0] = name
# li[0] = li[0].capitalize()
# li[2] = '苑日天'
# print(li[2].replace('昊','ritian'))
# li[2] = li[2].replace('昊','ritian')
# li[3][0] = li[3][0].upper()
# print(li)
|
总结
以上所述是小编给大家介绍的Python Learning 列表的更多操作及示例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
原文链接:https://www.jianshu.com/p/7ba89a902417