三元运算
a = 2 b = 5 val = a if a < b else b print(val) #2 # 如果 a 小于 b val 就等于a 反之等于b
函数
例1 定义一个函数
def sayhi():
print('hhhhh')
print(sayhi) # 函数的内存地址
sayhi() #调用函数
#结果
#<function sayhi at 0x0000000002592488>
#hhhhh
函数传参
# 2 函数传参
def calc(x,y):
res = x**y
return res #返回函数的执行结果
c = calc(2,2)
print(c) # 4
函数参数说明
"""
函数参数:
形参变量
只有在被调用时才分配内存单元,在调用结束时,即释放所分配的内存单元,因此形参只在函数内部有效。
函数调用结束返回主调用函数后则不能再使用该形参变量
实参
可以是常量 变量 表达式 函数等,无论实参是何种类型的量,在进行函数调用时,它们必须有确定的值,
以便把这些值传送给形参。 因此应预先用赋值 输入等办法使参数获得确定值
"""
形参与实参 例子说明
# 形参 与实参的说明
def calc(x,y): # x, y 是形参
res = x**y
return res
c = calc(2,4) # 2, 4 是实参
print(c) #16
默认参数
def stu_register(name,age,country,course):
print("--------注册学生信息---------")
print("姓名:",name)
print("age: ",age)
print("国籍:",country)
print("课程:",course)
stu_register("张三",22,"CN","python")
'''
--------注册学生信息---------
姓名: 张三
age: 22
国籍: CN
课程: python
'''
# course 设置默认参数 默认参数都是放在最后位
def stu_register(name,age,course,country="CN"):
print("--------注册学生信息---------")
print("姓名:",name)
print("age: ",age)
print("国籍:",country)
print("课程:",course)
stu_register("张三",22,"python")
'''
--------注册学生信息---------
姓名: 张三
age: 22
国籍: CN
课程: python
'''
关键参数 正常情况下 给函数传参数要按顺序, 不想按顺序机可以用关键参数, 只需指定参数名即可(指定了参数名的参数就叫关键参数) 关键参数必须放在位置参数之后
def stu_register(name, age, course='PY' ,country='CN'):
print("----注册学生信息------")
print("姓名:", name)
print("age:", age)
print("国籍:", country)
print("课程:", course)
stu_register("王山炮",course='PY', age=22,country='JP' )
######下面2种调用方式是不允许的
# stu_register("王山炮",course='PY',22,country='JP' )
# stu_register("王山炮",22,age=25,country='JP' )
非固定参数 *args **kwargs
# *args
def stu_register(name,age,*args): # *args 会把多传入的参数变成一个元组形式
print(name,age,args)
stu_register("Alex",22) #Alex 22 ()
stu_register("Jack",32,"CN","Python") #Jack 32 ('CN', 'Python')
#**kwargs
def stu_register(name,age,*args,**kwargs): # *kwargs 会把多传入的参数变成一个dict形式
print(name,age,args,kwargs)
stu_register("Jack",32,"CN","Python",sex="Male",province="ShanDong")
# Jack 32 ('CN', 'Python') {'sex': 'Male', 'province': 'ShanDong'}
函数返回值说明
## 函数返回值
def stu_register(name, age, course='PY' ,country='CN'):
print("----注册学生信息------")
print("姓名:", name)
print("age:", age)
print("国籍:", country)
print("课程:", course)
if age > 22:
return False
else:
return True
resgistriation_status = stu_register("张三",19,course="py",country='JP')
if resgistriation_status:
print("注册成功")
else:
print("too old to be a student.")
# 说明 函数在执行过程中只要遇到return语句, 就会停止执行并返回结果, return 代表着函数的结束
# 如果未来函数中指定return, 那这个函数返回值为None
全局变量与局部变量
作用域即活动的范围
全局范围:全局存活,全局有效
局部范围:临时存活,局部有效
在函数中修改全局变量可使用global来进行修改
name = 'augustyang'
# global 修改全局变量
def change_name():
global name
name = 'alex'
print(name)
change_name()
print(name)
'''
结果
alex
alex
'''
匿名函数 lambda
def calc(x,y):
if x < y:
return x*y
else:
return x/y
print(calc(1,2)) # 2
func = lambda x,y:x*y if x < y else x/y
print(func(1,2)) #2
# lambda
data = list(range(10))
for index, i in enumerate(data):
data[index] = i*i
print(data)
## 结果 [0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
def f2(n):
return n*n
func = (map(lambda x:x*x,[1,2,3,4,5,6,7,8,9]))
print(list(func))
# 结果 [1, 4, 9, 16, 25, 36, 49, 64, 81]
递归函数
def calc(x):
v = int(x/2)
print(v)
if v > 0:
calc(v)
else:
print("----------------")
print(x)
calc(10)
'''
结果:
5
2
1
0
----------------
1
2
5
10
'''
# 递归1
def calc(n):
v = int(n/2)
print(v)
if v == 0:
return
calc(v)
calc(10)
'''
5
2
1
0
'''
# 递归2
def calc1(n):
v = int(n/2)
print(v)
if v > 0:
calc1(v)
print(n)
calc1(10)
'''
5
2
1
0
1
2
5
10
'''
import time
person_list=['alex','wupeiqi','yuanhao','linhaifeng']
def ask_way(person_list):
print('-'*60)
if len(person_list) == 0:
return '没人知道'
person=person_list.pop(0)
if person == 'linhaifeng':
return '%s说:我知道,老男孩就在沙河汇德商厦,下地铁就是' %person
print('hi 美男[%s],敢问路在何方' %person)
print('%s回答道:我不知道,但念你慧眼识猪,你等着,我帮你问问%s...' %(person,person_list))
time.sleep(3)
res=ask_way(person_list)
# print('%s问的结果是: %res' %(person,res))
return res
res=ask_way(person_list)
print(res)
尾递归
# 尾递归
def factorial(n):
if n == 1:
return 1
return n * factorial(n-1)
print(factorial(996))
递归特性
- 必须有一个明确的结束条件
- 每次进入更深一层递归时,问题规模相比上次递归都应有所减少
- 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出)
来源:https://www.cnblogs.com/augustyang/p/10477184.html