2020-11-17

Python 序列与循环

什么是序列?

序列是被排成一列的数据,也就是说是有序的数据集合。

常用的序列有:

  1. 列表 list
  2. 元组 tuple
  3. 字符串 string

序列的通用操作

  • 切片([开始:结束:步长])
  • 序列的加法(+)
  • 序列的乘法(*)
  • 成员资格判断(in)
  • 求最大值 (max)
  • 求最小值 (min)
  • 求序列长度 (len)
  • 求和(sum) #字符串不能求和

序列的遍历

foo = 'abc'
for  i  in foo:
	print(i)  #打印的结果为a b c
	
for  i,v  in enumerate(foo):
	# i为取出的元素的索引,v为每次取出的值
	print(i,v)   #打印的结果为0 a  1 b  2 c

range函数

range(开始,结束,步长) 生成在设定范围内的整数数据对象

 for  i  in range(10):
	print(i)   
#打印的结果为0 1 2 3 4 5 6 7 8 9 

什么是列表?

  • 列表(list)可以按顺序存放数据的容器.数据可以是任意类型.可根据需要对数据进行添加\弹出\修改数据。
  • 列表是使用方括号括把用逗号分隔的不同的数据项括起来的数据。
  • 列表名 = [元素1,元素2,··· ···]

列表的创建

list1 = ['宫爆鸡丁', '小炒肉',20]
嵌套列表
menu=[  [“羊肉泡馍”,20],				
                [“宫保鸡丁”,10],
                [“鱼香肉丝”,10] 
              ]

从列表中取值

格式为:列表名[索引]

menu=[“羊肉泡馍”,“宫保鸡丁”,“鱼香肉丝”]
print(menu[0])
print(menu[1])
print(menu[2])

元素的修改

menu=[“羊肉泡馍”,
             “宫保鸡丁”,
             “鱼香肉丝”]

menu[0]  = ‘红烧肉’
print(menu)

列表的常用方法

  • 列表.append(数据) :追加数据
  • 列表名.extend(lis) : 一个列表尾部追加另一个列表就是列表扩展 lis3 = lis1 + lis2 : 将lis1和lis2合并生成新的lis3
extend与+的区别

将list2中的元素追加到了list1中,list1发生变化;
+号是产生了一个新的列表,list1和list2都没有变化。

  • list.insert(index,data) : 在范围内任意位置添加
  • x=list.pop(索引值) : pop() 函数用于移除列表中的一个元素(默认最后一个元素),并且返回该元素的值。(X为移除的元素)
  • 列表名.remove(元素名) : 删除首次出现的指定元素,如果列表中不存在要删除的元素,则抛出异常
  • 列表名.clear() : 清空列表,最后得到一个空列表
  • del 列表名 : 删除整个列表
  • del 列表名[索引] : 删除列表中的某个元素
  • 列表名.sort() 列表对象的sort方法进行原地排序,会改变原列表
  • newlist = sorted(oldlist)
  • 内置函数sorted方法排序,并返回修改后的新列表
  • 列表名.reverse() 元素原地反转
  • 列表名.count() 统计元素出现次数

列表推导式

样式为 :[ 元素 for 元素 in 序列 if 条件 ]

is = [ i  for  i in range(10)  if i %2 == 0 ]  # 求10以内的偶数

可以认为是下面代码的简写形式

lis1 = []
for i in range(10):
	if i % 2 ==0:
		lis1.append(i)

while循环

主要框架有一下几个代码:
  • While 条件: #当条件成立时循环

  • 循环体

  • while True:

    • print(“这是一个死循环”)
  • break :退出并结束循环

  • continue :跳出本次循环,从下一次循环继续执行

元组

  • 元组和列表非常相似,也是有序的线性表,本质上最大的区别就是内容不可变,我们可以使用元组来存储,效率会更高。
元组的定义
  • 如果元组中只有一个元素,一定要在这个元素后面加一个逗号,否则不认为是元组如下
    menu = (‘红烧鱼’) #错
    menu = (‘红烧鱼’,) #对

生成器推导式

generator 生成器

  • 它的工作方式是每次处理一个对象,而不是一口气处理,这样做的潜在优点是可以节省大量的内存。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值