python全栈开发 day14 十四、三元运算符,推导式,匿名内置函数

一、三元(目)运算符

1、就是if...else...语法糖

前提:if和else只有一条语句

# 原来的做法

cmd = input('cmd:>>>')
if cmd.isdigit():
    print('可以转化为数字')
else:
    print('不可以转化为数字')

# 现在的做法
cmd = input('cnd:>>>')
print('可以转化为数字') if cmd.isdigit() else print('不可以转化为数字')


# 案例:得到两个数大值
a = 1000
b = 200
res = a if a > b else b    # 求大值
print(res)

# 三元运算符的结果不一定要与条件直接性关系
res = b if a > b else a    # 求小值
print(res)


2、推导式:列表(元组)与字典的转换语法糖

# 列表(元组)推导式
dic = {'a': 100, 'b': 200, 'c': 300}    # >   [('a', 100), ('b', 200), ('c', 300)]
res = [(k, v) for k, v in dic.items()]
print(res)    # 结果为 [('a', 100), ('b', 200), ('c', 300)]
# 字典推导式
ls = [('a', 100), ('b', 200), ('c', 300)]    # >  {'a': 100, 'b': 200, 'c': 300}
res = {k: v for k, v in ls}
print(res)   # 结果为 {'a': 100, 'b': 200, 'c': 300}


3、案例

# range(10)  可以被推倒为列表

res= [arg for arg in range(10)]
print(res)    # 结果为 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]

dic = {arg: 'a' for arg in range(10)}
print(dic)


# 迭代出可解压为的单列容器可以推导出字典
res = {k: v for k, v in enumerate('abcd')}
print(res)    # 结果为 {0: 'a', 1: 'b', 2: 'c', 3: 'd'}

二、递归

1、定义:回溯与递推 ***

回溯:询问答案的过程

递推:推出答案的过程 

2、前提:***** 

回溯到一个有具体结果的值,开始递推

回溯与递推的条件要有规律  

3、递归本质:函数的自我调用(自己调自己)

count = 0
def fn():
    global count
    count += 1
    if count > 10:
        return
    fn()
fn()


# 函数间接调用自己:一旦产生了循环调用,就产生了递归
def a():
    b()
def b():
    c()
def c():
    a()
a()


4、案例

# 询问第一个人年龄,回溯条件 小两岁,第五个人说出自己的年龄,推导出第一个人年龄
# 条件:下一个人的年龄比这个人年纪大两岁
def get_age(num):  # 得到年龄
    if num == 1:
        return 58
    age = get_age(num - 1) - 2
    return age
res = get_age(5)
print(res)




# 阶乘
# 5! = 5 * 4!    4! = 4 * 3!   ...   2! = 2 * 1
def factorial(num):
    if num == 1:
        return 1
    temp = num * factorial(num - 1)
    return temp
res = factorial(5)
print(res)

三、匿名函数

1、定义:没有函数名,没有函数体,只有一个返回值的函数

2、语法 lambda 参数列表 :一个返回值表达式

3、关键字:lambda | 参数列表省略() | 返回值return关键字也被省略

res = lambda x, y: x + y
print(res)                 # 结果为 <function <lambda> at 0x0000000002051E18>
print(res(100, 200))       # 结果为 300


4、应用场景

猜你喜欢

转载自www.cnblogs.com/zhangguosheng1121/p/10656471.html