Python Learning 列表的更多操作及示例代码

yipeiwu_com5年前Python基础

遍历列表-for循环

列表中存储的元素可能非常多,如果想一个一个的访问列表中的元素,可能是一件十分头疼的事。那有没有什么好的办法呢?当然有!使用 for循环

假如有一个食物名单列表,通过 for循环 将列表中的食物名称都打印出来

# 定义一个食物名单列表
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循环每次从列表中取出一个元素后,都会进入代码块中执行一遍,即输出元素的名称;直到将列表所有的元素都遍历一次后,循环停止

# 定义一个食物名单列表
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中;现在想知道小明与小红所喜欢的食物是否有相同的,则可用如下方式:

# 小明喜欢的食物列表 
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() 快速创建一系列数字

for value in range(1,6):
  print(value)

输出:

rnage(1, 6) 会生成从1到5的数字,6表示到6的时候就停止创建动作,如果想创建1到1000的数字,则是 range(1, 1001)

通过 list() 可以将 range() 创建的数字转换成列表

# 输出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() 返回的是一个 可迭代对象 ,经过转换后才是一个列表对象

还可以通过指定 步长 ,来生成一系列偶数

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)

一些简单的、常用的数字列表统计函数:

# 定义一个偶数列表
numbers = list(range(2,21,2))

# 求数值列表中最小的元素值
print(min(numbers))
# 求数值列表中最大的元素值
print(max(numbers))
# 求数值列表所有元素的和
print(sum(numbers))

输出:

列表解析

直接看下面代码

# 定义一个偶数列表
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

这里需要注意的是,循环后面没有冒号,可以理解为将循环体的代码块精简成了一个表达式

列表切片

只获取列表的部分元素,这样的操作叫作 切片

切片通过列表的索引进行操作,即从哪个索引开始,到哪个索引结果,将这段元素取出

# 定义一个食物列表
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的三个元素

如果省略冒号前的数字,则表示从开始的位置取值

# 从索引0开始,取到索引4之前的所有值
foods[:4]
如果省略冒号后的数字,则表示一直取到列表的末尾
# 从索引1开始,一下取到列表结束的位置
foods[1:]
如果只有冒号,表示取所有数据
# 取所有数据
foods[:]

还可能使用负数

# 从倒数3个元素开始,一直取到末尾
foods[-3:]

for循环与切片的结合

# 定义一个食物列表
foods = ['potato', 'tomato', 'noodles', 'apple', 'pizza']
# 打印第2个到第4个元素
for food in foods[1:4]:
  print(food)

输出:

tomato  noodles  apple

关于列表的复制

先来看个例子

foods1 = ['potato', 'tomato', 'noodles', 'apple', 'pizza']
foods2 = foods1
print(foods1)
print(foods2)

将foods1列表赋值给foods2列表,看似是一个复制动作,但foods1与foods2实际上是一个对象

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也变了

复制需要另外创建出一个一模一样的对象出来,但它们必须的确是两个对象才行

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不同,则不是同一个对象

简单谈一下元组

元组的使用与列表类似,不同的,列表是可改变的,而元组不是可改变的;列表用 [] 来定义,元组则使用 () 来定义

# 定义一个元组
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(列表)

列表是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 列表的更多操作及示例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对【听图阁-专注于Python设计】网站的支持!

相关文章

Windows下Anaconda的安装和简单使用方法

Windows下Anaconda的安装和简单使用方法

Anaconda is a completely free Python distribution (including for commercial use and redistrib...

在Python中使用lambda高效操作列表的教程

介绍 lambda Python用于支持将函数赋值给变量的一个操作符 默认是返回的,所以不用再加return关键字,不然会报错 result = lambda x: x * x re...

Python语法分析之字符串格式化

前序 There should be one - and preferably only one - obvious way to do it. ———— the Zen of Pyt...

python机器学习之神经网络(一)

python机器学习之神经网络(一)

python有专门的神经网络库,但为了加深印象,我自己在numpy库的基础上,自己编写了一个简单的神经网络程序,是基于Rosenblatt感知器的,这个感知器建立在一个线性神经元之上,神...

Python实现的登录验证系统完整案例【基于搭建的MVC框架】

Python实现的登录验证系统完整案例【基于搭建的MVC框架】

本文实例讲述了Python实现的登录验证系统。分享给大家供大家参考,具体如下: 小型登录注册验证系统 一、概述 ​ 使用Redis+MySQL数据库实现一个小型的登录注册验证...