Python基础知识学习——Day5

for 循环和可迭代对象遍历

for x in (20,30,40):
	print(x*3)

可迭代对象

Python 包含以下几种可迭代对象:

  • 序列
  • 字典
  • 迭代器对象
  • 生成器函数
  • 文件对象
#遍历字符串中的字符
for x in "sxt001":
	print(x)
#遍历字典
d = {'name':'gaoqi','age':18,'address':'西三旗001 号楼'}
for x in d: #遍历字典所有的key
	print(x)
for x in d.keys():#遍历字典所有的key
	print(x)
for x in d.values():#遍历字典所有的value
	print(x)
for x in d.items():#遍历字典所有的"键值对"
	print(x)

range对象

range 对象是一个迭代器对象,用来产生指定范围的数字序列。格式为:range(start, end [,step])

#利用for 循环,计算1-100 之间数字的累加和;计算1-100 之间偶数的累加和,计算1-100 之间奇数的累加和
sum_all = 0 #1-100 所有数的累加和
sum_even = 0 #1-100 偶数的累加和
sum_odd = 0 #1-100 奇数的累加和
for num in range(101):
	sum_all += num
	if num%2==0:sum_even += num
	else:sum_odd += num
print("1-100 累加总和{0},奇数和{1},偶数和{2}".format(sum_all,sum_odd,sum_even))

嵌套循环

for x in range(5):
	for y in range(5):
		print(x,end="\t")
	print() #仅用于换行

break 语句

  • break 语句可用于while和for循环,用来结束整个循环。当有嵌套循环时,break 语句只能跳出最近一层的循环。
while True:
	a = input("请输入一个字符(输入Q 或q 结束)")
	if a.upper()=='Q':
		print("循环结束,退出")
		break
	else:
		print(a)

continue 语句

  • continue 语句用于结束本次循环,继续下一次。多个循环嵌套时,continue 也是应用于最近的一层循环。
#要求输入员工的薪资,若薪资小于0 则重新输入。最后打印出录入员工的数量和薪资明细,以及平均薪资
empNum = 0
salarySum= 0
salarys = []
while True:
	s = input("请输入员工的薪资(按Q或q结束)")
	if s.upper()=='Q':
		print("录入完成,退出")
		break
	if float(s)<0:
		continue
	empNum +=1
	salarys.append(float(s))
	salarySum += float(s)
print("员工数{0}".format(empNum))
print("录入薪资:",salarys)
print("平均薪资{0}".format(salarySum/empNum))

else 语句

  • while、for 循环可以附带一个else 语句(可选)。如果for、while 语句没有被break 语句结束,则会执行else 子句,否则不执行。
#员工一共4 人。录入这4 位员工的薪资。全部录入后,打印提示“您已经全部录入4 名员工的薪资”。最后,打印输出录入的薪资和平均薪资
salarySum= 0
salarys = []
for i in range(4):
	s = input("请输入一共4 名员工的薪资(按Q 或q 中途结束)")
	if s.upper()=='Q':
		print("录入完成,退出")
	break
	if float(s)<0:
		continue
	salarys.append(float(s))
	salarySum += float(s)
else:
	print("您已经全部录入4 名员工的薪资")
print("录入薪资:",salarys)
print("平均薪资{0}".format(salarySum/4))

循环代码优化

  • 编写循环时,遵守下面三个原则可以大大提高运行效率,避免不必要的低效计算:
  1. 尽量减少循环内部不必要的计算
  2. 嵌套循环中,尽量减少内层循环的计算,尽可能向外提。
  3. 局部变量查询较快,尽量使用局部变量
#循环代码优化测试
import time
start = time.time()
for i in range(1000):
	result = []
	for m in range(10000):
		result.append(i*1000+m*100)
end = time.time()
print("耗时:{0}".format((end-start)))

start2 = time.time()
for i in range(1000):
	result = []
	c = i*1000
	for m in range(10000):
		result.append(c+m*100)
end2 = time.time()
print("耗时:{0}".format((end2-start2)))

使用zip()并行迭代

  • 我们可以通过zip()函数对多个序列进行并行迭代,zip()函数在最短序列“用完”时就会停止。
#测试zip()并行迭代
names = ("高淇","高老二","高老三","高老四")
ages = (18,16,20,25)
jobs = ("老师","程序员","公务员")
for name,age,job in zip(names,ages,jobs):
	print("{0}--{1}--{2}".format(name,age,job))

推导式创建序列

  • 列表推导式

    列表推导式生成列表对象,语法如下:[表达式for item in 可迭代对象] 或者:{表达式for item in 可迭代对象if 条件判断}

>>> [x for x in range(1,5)]
[1, 2, 3, 4]
>>> [x*2 for x in range(1,5)]
[2, 4, 6, 8]
>>> [x*2 for x in range(1,20) if x%5==0 ]
[10, 20, 30]
>>> [a for a in "abcdefg"]
['a', 'b', 'c', 'd', 'e', 'f', 'g']
  • 字典推导式

    字典的推导式生成字典对象,格式如下:
    {key_expression : value_expression for 表达式in 可迭代对象}

>>> my_text = ' i love you, i love sxt, i love gaoqi'
>>> char_count = {c:my_text.count(c) for c in my_text}
>>> char_count
{' ': 9, 'i': 4, 'l': 3, 'o': 5, 'v': 3, 'e': 3, 'y': 1, 'u': 1, ',': 2, 's': 1, 'x': 1, 't': 1, 'g': 1, 'a': 1, 'q': 1}
  • 集合推导式

    集合推导式生成集合,和列表推导式的语法格式类似:{表达式for item in 可迭代对象}或者:{表达式for item in 可迭代对象if 条件判断}

>>> {x for x in range(1,100) if x%9==0}
{99, 36, 72, 9, 45, 81, 18, 54, 90, 27, 63}

Python 函数的分类

  • 内置函数
    我们前面使用的str()、list()、len()等这些都是内置函数,我们可以拿来直接使用。
  • 标准库函数
    我们可以通过import 语句导入库,然后使用其中定义的函数
  • 第三方库函数
    Python 社区也提供了很多高质量的库。下载安装这些库后,也是通过import 语句导入,然后可以使用这些第三方库的函数
  • 用户自定义函数
    用户自己定义的函数,显然也是开发中适应用户自身需求定义的函数。今天我们学习的就是如何自定义函数。

核心要点

  • 定义函数的语法如下:
def 函数名([参数列表]) :
	'''文档字符串'''
	函数体/若干语句
  • 我们使用def 来定义函数,然后就是一个空格和函数名称
  • 参数列表
    (1) 圆括号内是形式参数列表,有多个参数则使用逗号隔开
    (2) 形式参数不需要声明类型,也不需要指定函数返回值类型
    (3) 无参数,也必须保留空的圆括号
    (4) 实参列表必须与形参列表一一对应
  • return 返回值
    (1) 如果函数体中包含return 语句,则结束函数执行并返回值
    (2) 如果函数体中不包含return 语句,则返回None 值
  • 调用函数之前,必须要先定义函数,即先调用def 创建函数对象
    (1) 内置函数对象会自动创建
    (2) 标准库和第三方库函数,通过import 导入模块时,会执行模块中的def 语句

形参和实参

def printMax(a,b):
	'''实现两个数的比较,并返回较大的值'''
	if a>b:
		print(a,'较大值')
	else:
		print(b,'较大值')

printMax(10,20)
printMax(30,5)

文档字符串(函数的注释)

  • 程序的可读性最重要,一般建议在函数体开始的部分附上函数定义说明,这就是“文档字符串”,也有人成为“函数的注释”。我们通过三个单引号或者三个双引号来实现,中间可以加入多行文字进行说明。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值