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、应用场景
匿名函数函数地址可以用一个变量接收,该变量就可以作为函数名来使用,但就违背了匿名初衷
结合内置函数来使用:内置函数某些参数需要一个函数地址。可以赋值一个有名函数名,也可以直接赋值匿名函数
res = max(100, 200, 500, 800)
print(res) # 结果为 800 res = max({100, 200, 500, 800})
print(res) # 结果为 800
def fn(arg):
print(arg)
return arg
ls = [100, 500, 400, 600, 300]
res = max(ls, key=fn)
print(res) ls = [100, 500, 400, 600, 300]
res1 = max(ls, key=lambda ele:ele)
print(res1) # 结果为 600
四、内置函数
1、max
iterable = [100, 200, 300, 500, 400]
res = max(iterable, key=lambda x: x)
print(res) # iterable = {
'bob':25000,
'jerry':360000,
'tom':4500,
'judy':10000
}
res = max(iterable, key=lambda x: iterable[x]) # x: 字典的k 返回值:做比较的值
print(res) # jerry iterable = {
'Bob': {'no': 100, 'salary': 12000},
'Tom': {'no': 200, 'salary': 37000},
'Jerry': {'no': 50, 'salary': 76000},
'Zero': {'no': 150, 'salary': 120},
}
res = max(iterable, key=lambda x: iterable[x]['no']) # 编号最大
print(res) # Tom res = max(iterable, key=lambda x: iterable[x]['salary']) # 薪资最高
print(res) # Jerry
2、min
iterable = {
'Bob': [100, 12000],
'Tom': [200, 37000],
'Jerry': [50, 76000],
'Zero': [150, 120],
}
res = min(iterable, key=lambda x: iterable[x][1]) # 薪资最低
print(res) # Zero
3、sorted
res = sorted([300, 200, 800, 1000, 600], key=lambda x: x)
print(res) # [200, 300, 600, 800, 1000]
res = sorted([300, 200, 800, 1000, 600], key=lambda x: x, reverse=True)
print(res) # [1000, 800, 600, 300, 200] iterable = {
'Bob': [100, 12000],
'Tom': [200, 37000],
'Jerry': [50, 76000],
'Zero': [150, 120],
}
res = sorted(iterable, key=lambda x: iterable[x][1]) # 按薪资排序由小到大
print(res) # ['Zero', 'Bob', 'Tom', 'Jerry']
4、map映射
res = map(lambda x: x+100, [10000, 20000, 30000, 40000])
print(list(res)) # [10100, 20100, 30100, 40100]
5、reduce合并
from functools import reduce
res = reduce(lambda f, n: f*n, [1, 2, 3, 4, 5])
print(res) # 结果为 120
day14 十四、三元运算符,推导式,匿名内置函数的更多相关文章
- day5--装饰器函数的信息打印,迭代器,生成器,列表推导式,内置函数
本文档主要内容: 一 装饰器函数的信息打印 二 迭代器 三 生成器 四 生成器表达式和列表推导式 五 内置函数 一 装饰器函数的信息打印 一个函数一旦被装饰器给装饰后,这个函数的信息使用原来的命令打印 ...
- Day 14 三元运算符,列表推导式,内置函数
三目运算符 ```python# 三目(元)运算符:就是 if...else...语法糖# 前提:简化if...else...结构,且两个分支有且只有一条语句# 注:三元运算符的结果不一定要与条件直接 ...
- python27期day12:推导式、内置函数、高阶函数、匿名函数、作业题
1.推导式:做一些有规律的数据结构 列表推导式: 普通循环模式: [加工后的变量 for 循环] 示例一:print([i for i in range(1,51)]) 结果:[1, 2, 3, 4, ...
- python函数知识五 推导式和内置函数一(了解)
17.推导式: 推导式:将for循环多行变成一行 list推导式:[] #普通模式 print([i for i in range(20)]) #循环模式 #[变量 for i in range(20 ...
- Python学习之路——三元运算符推导式
三元运算符 # 生成器:包含yield关键字的函数就是生成器 def my_generator(): yield 1 yield 2 yield 3 g_obj = my_generator() # ...
- Day05:装饰器,三元表达式,函数的递归,匿名/内置函数,迭代器,模块,开发目录
上节课复习:1.函数的对象 函数可以被当作数据取处理2.函数嵌套 嵌套调用:在调用一个函数时,函数体代码又调用了其他函数 嵌套定义:在一个函数内部又定义了另一个函数 def foo( ...
- WebAssembly学习(四):AssemblyScript - 结构体系与内置函数
一.结构体系 1.编译 编译器的结构相对保守. 提供源文件,其文本被标记化并解析为抽象语法树. 这里执行语法级检查. 一旦解析了所有引用的源文件,就构造一个程序并从AST初始化. 在这里进行合理性检查 ...
- 一起talk C栗子吧(第一百二十四回:C语言实例--内置宏)
各位看官们,大家好,上一回中咱们说的是显示变量和函数地址的样例,这一回咱们说的样例是:内置宏.闲话休提,言归正转.让我们一起talk C栗子吧! 看官们,我们在编译程序的时候,假设有语法错误,编译器就 ...
- 十二、python沉淀之路--内置函数
1.abs函数,求绝对值. a = abs(-3) print(a) 返回:3 2.all函数:判断是否是可迭代对象. 官方解释:Return True if bool(x) is True for ...
随机推荐
- sqlite "insert or replace" 和 "insert or ignore" 用法
insert or replace:如果不存在就插入,存在就更新insert or ignore:如果不存在就插入,存在就忽略只对UNIQUE约束的字段起作用.举例:建表:CREATE TABLE T ...
- 【jQuery:遍历同样class的全部值,遍历某一列td的值】
jsp代码: Html代码 <c:forEach var="main" items="${mainPage.list }"> <tr> ...
- [转] 阿里研究员谷朴:API 设计最佳实践的思考
API是软件系统的核心,而软件系统的复杂度Complexity是大规模软件系统能否成功最重要的因素.但复杂度Complexity并非某一个单独的问题能完全败坏的,而是在系统设计尤其是API设计层面很多 ...
- Nload(CentOS网速的实时监控)
Nload(CentOS网速的实时监控)的安装和安装过程中的问题 I. 安装 Download the latest rpmforge-release rpm from wget ftp://ftp. ...
- ip代理优化
如何保证可用ip不低于2000个,代理ip池优化策略 第一:获得大量ip: 第二:验证可用ip: 第三:监控可用ip: 第三:保证可用ip不低于3000或者5000: 截图是实时可用ip数量 心得:不 ...
- 物联网架构成长之路(29)-Jenkins环境搭建
0. 说明 哈哈,前面中间插入了一篇Eclipse增加Git插件,在此之前真的没有用过GIT. 1. 运行Jenkins 这里为了方便,还是用Docker方式安装,由于这个是标准的war报,不对Doc ...
- 每天进步一点点——mysql——mysqlbinlog
一. 简单介绍 mysqlbinlog:用于查看server生成的二进制日志的工具. 二. 命令格式 mysqlbinlog 选项日志文件1 三. 经常使用參数 ...
- how-can-i-see-the-size-of-files-and-directories-in-linux
https://stackoverflow.com/questions/11720079/how-can-i-see-the-size-of-files-and-directories-in-linu ...
- ExtJS6 根据Value设置单元格颜色
renderer : function(value, meta) { if(parseInt(value) > 0) { meta.style = ""; } else { ...
- Tensorflow 与Caffe(转)
TensorFlow TensorFlow 是相对高阶的机器学习库,用户可以方便地用它设计神经网络结构,而不必为了追求高效率的实现亲自写 C++或 CUDA 代码.它和 Theano 一样都支持自动求 ...