l1 = [1,2,3,4,5,‘a‘,‘b‘,‘dfsa‘,3]
count = 0
for j in l1:
count += 1
print(count)
要是计算多个序列的个数的话:
重复代码多
可读性差
#函数的产生:
函数就是封装一个功能
li = [1,2,3,4,5]
def my_len():
#def关键字 定义一个函数
#my_len:函数名书写规则与变量相同
#函数名后必须加()
count = 0
for i in li:
count += 1 ----->函数体
print(count)
my_len()
函数的执行:函数名+()
#函数的返回值:
**return
不要在函数中写print
1,在函数中,遇到return结束函数。
2,将值返回给函数的调用者
无return 返回None
return None 返回None
return 1个值 该值是什么就直接返回给函数的调用者
return 多个值 将多个值放到一个元组里返回给函数的调用者
#函数的传参:
两方面:
实参:1.位置传参:按顺序,一一对应
练习:写一个函数:简单的比较a,b大小:
三元运算:z = a if a > b else b
return z
2.关键字传参:不按顺序,一一对应
3.混合传参:所有的位置参数在最前面,
关键字参数永远在最后面。
形参:1.位置传参:按顺序,一一对应
2.默认参数:传参则覆盖,不传则默认。
位置参数永远在默认参数前面
写一个函数完成三次登陆功能
# def user_in():
# i = 0
# name = ‘李四‘
# word = ‘123456‘
# while i < 3 :
# username = input(‘请输入用户名‘).strip()
# password = input(‘请输入密码‘).strip()
# if username ==name and password == word:
# return ‘登陆成功‘
#
# else:
# print( ‘登录失败,你还有{}次机会‘.format(2-i))
# i += 1
# if i == 3:
# return ‘你没有机会了‘
# print(user_in())