day20 匿名函数,内置函数,面向过程编程
有名函数
def f1():
print('my name is f1')
f1()
my name is f1
匿名函数
- 没有函数名的函数
- lambda关键字定义
- 语法:
- lambda x,y(参数): x+y(逻辑代码)
# 这样做就成了一个有名函数了
f = lambda x,y:x+y
print(f(1, 2))
# 这样调用没有什么实际意义
print((lambda x,y:x+y)(1, 2))
3
3
- 匿名函数也能调用,但是调用需要注意只能使用一次,匿名函数一般不单独使用,而是与max(),min(),map(),sorted(),filter()这些内置函数一起使用
max()
- 最大值
# 找到工资最高的人
salary_dict = {'leijun':17000, 'lalala': 19000}
max_salary = max(salary_dict) # 默认是按照键取
print(max_salary)
leijun
def key(res): # res = 'leijun','lalala'
return salary_dict[res]
max_salary = max(salary_dict, key=key)
print(max_salary)
lalala
- max中封装的过程
- salary_dict变成迭代器对象salary_dict_iter
- res = salary_dict_iter.next
- 把res丢入函数func中,17000,19000
- 得到函数的返回值,把这个返回值作为判断依据
# 自己写一个max函数
def max(iterable, key=None):
salary_dict_iter = iterable.__iter__()
init_num = 0
for salary in salary_dict_iter:
func_res = key(salary)
if func_res > init_num:
init_num, func_res = func_res, init_num
return init_num
# 上面的key函数,可以写成匿名函数
salary_max = max(salary_dict, key=lambda name:salary_dict[name])
print(salary_max)
lalala
min()
- 最小值
salary_min = min(salary_dict, key= lambda name:salary_dict[name])
print(salary_min)
leijun
sorted
- 排序
# 排序
salary_dict_sorted1 = sorted(salary_dict)
print(salary_dict_sorted1)
salary_dict_sorted2= sorted(salary_dict, key = lambda name:salary_dict[name])
print(salary_dict_sorted)
['lalala', 'leijun']
['leijun', 'lalala']
map
- 映射
name_list = ['nick', 'tank', 'sean']
res = map(lambda name:f'{name} dsb', name_list)
print(list(res))
['nick dsb', 'tank dsb', 'sean dsb']
filter
- 过滤
lis = ['jason dsb', 'tank dsb', 'sean dsb','nick']
res = filter(lambda x:not x.endswith('dsb'),lis)
print(list(res))
['nick']
内置函数
1.enumerate
- 获取索引和值
lis = ['a', 'b', 'c']
for i,a in enumerate(lis):
print(i, a)
0 a
1 b
2 c
2.eval()
- 去掉字符串的引号,还原原本的数据类型
- python3的input+eval就等于python2的input
num = '[1, 2, 3]'
print(list(eval(num)))
[1, 2, 3]
3.abs()
- 绝对值
print(abs(-100))
100
4.bin()/oct()/hex()
- 进制转换
print(bin(777))
print(oct(777))
print(hex(777))
0b1100001001
0o1411
0x309
5.globals()/locals
- 获取当前的全局/局部变量
print(globals())
6.sum()
- 求和
print(sum([1, 2, 3, 4]))
10
7._import_()
- 通过字符串格式导入模块
m = __import__('time')
print(m.time())
1560153794.2662559
8.bytes()
- unicode转utf-8
print('中文'.encode('utf-8'))
print(bytes('中文', 'utf-8'))
b'\xe4\xb8\xad\xe6\x96\x87'
b'\xe4\xb8\xad\xe6\x96\x87'
9.chr()/ord()
- ascill码中的对应关系
print(chr(97))
print(ord('a'))
a
97
10.divmod()
- 求商取余
print(divmod(10, 3))
(3, 1)
11.hash()
- 可哈希不可变,不可哈希可变
- 可哈希就返回,不可哈希就报错
print(hash(10))
# print(hash([1, 22]))
10
12.all()/any()
- all全为真返回True
- any有真就返回True
print(all([0, 1, 2, 3]))
print(any([0, 1, 2, 3]))
False
True
13.dir()
- 把模块所有的方法读取出来
import time
print(dir(time))
['_STRUCT_TM_ITEMS', '__doc__', '__loader__', '__name__', '__package__', '__spec__', 'altzone', 'asctime', 'clock', 'ctime', 'daylight', 'get_clock_info', 'gmtime', 'localtime', 'mktime', 'monotonic', 'perf_counter', 'process_time', 'sleep', 'strftime', 'strptime', 'struct_time', 'time', 'timezone', 'tzname']
14.pow()
- 求幂后求余
- 可以单独求幂
- 历史遗留,可以直接用算数运算替代
print(pow(3, 2, 4))
1
15.round()
- 四舍五入
print(round(3.4))
3
16.slice
- 用切片就可以了
- 历史遗留问题
lis = ['a', 'b', 'c']
a = slice(1, 3, 1)
print(lis[a]) # lis[1:3:1]
['b', 'c']
面向过程编程
按照一定的顺序,其中每一步都可以看做是函数,当前函数的输入是上一个函数的输出,这就叫面向过程编程
优点:
- 逻辑清晰,简单明了
- 每个函数都可以独立的写出来
缺点:
- 相互之间会有一定的联系,其中一个断了,后面的也断了
- 可扩展性差
例如:ATM
day20 匿名函数,内置函数,面向过程编程的更多相关文章
- Python第七天 函数 函数参数 函数里的变量 函数返回值 多类型传值 函数递归调用 匿名函数 内置函数
Python第七天 函数 函数参数 函数里的变量 函数返回值 多类型传值 函数递归调用 匿名函数 内置函数 目录 Pycharm使用技巧(转载) Python第一天 ...
- python 匿名函数&内置函数
匿名函数:为了解决那些功能很简单的需求而设计的一句话函数怎么定义匿名函数: cal = lambda x : x*x # cal是函数名,lambda是定义匿名函数的关键字 冒号前面的额x是参数即函数 ...
- python学习day11 函数Ⅲ (内置函数与lambda表达式)
函数Ⅲ(内置函数&lambda表达式) 1.函数小高级 函数可以当做变量来使用: def func(): print(123) func_list = [func, func, func] # ...
- Python学习笔记014——迭代工具函数 内置函数enumerate()
1 描述 enumerate() 函数用于将一个可遍历的数据对象(如列表.元组或字符串)组合为一个索引序列,同时列出数据和数据下标,一般用在 for 循环当中. 2 语法 enumerate(sequ ...
- python 函数--内置函数
一.内置函数 内置函数是python自带的一系列常用函数. 二.python3中内置函数 内置功能 abs() delattr() hash() memoryview() set() ...
- python基础12_匿名_内置函数
一个二分查找的示例: # 二分查找 示例 data = [1, 3, 6, 7, 9, 12, 14, 16, 17, 18, 20, 21, 22, 23, 30, 32, 33, 35, 36, ...
- Python——day14 三目运算、推导式、递归、匿名、内置函数
一.三目(元)运算符 定义:就是 if...else...语法糖前提:简化if...else...结构,且两个分支有且只有一条语句注:三元运算符的结果不一定要与条件直接性关系 cmd = input ...
- python基础之递归,匿名,内置函数
递归函数: 什么是递归函数? 函数递归调用:在调用一个函数的过程中,又直接或间接地调用了该函数本身. 递归必须要有两个明确的阶段: ①递推:一层一层递归调用下去,强调:每进入下一层问题规模减少 ②回溯 ...
- Python 函数递归-三元表达式-列表生成式-字典生成式-匿名函数-内置函数
上节课复习: 1. 无参装饰器 def 装饰器名字(func): def wrapper(*args,**kwargs): res = func(*args,**kwargs) return res ...
随机推荐
- spring重点一:处理对象创建时间 个数以及方式
/** * 1) 对象创建: 单例/多例(个数) * scope="singleton", 默认值, 即 默认是单例 [service/dao/工具类] * scope=&quo ...
- 第一章 JavaScript 简介
1.1 JavaScript 的简史 JavaScript 诞生于1995年 ,后由 欧洲计算机制造商协会( ECMA,European Computer Manufacturers Associ ...
- Project Euler 24 Lexicographic permutations( 康拓逆展开 )
题意: 排列指的是将一组物体进行有顺序的放置.例如,3124是数字1.2.3.4的一个排列.如果把所有排列按照数字大小或字母先后进行排序,我们称之为字典序排列.0.1.2的字典序排列是:012 021 ...
- BZOJ 2161 布娃娃 (主席树)
题面 想了一个主席树做法 我们把每个区间的两个端点拆开 对$L,R$分别从小到大排序,分别从左到右依次把对应标号的$c_{i}$插入到权值主席树里 每次查询$p_{i}$,在排序后的$L,R$数组上分 ...
- ElasticSearch 深度分页解决方案
常见深度分页方式 from+size 另一种分页方式 scroll scroll + scan search_after 的方式 es 库 scroll search 的实现 常见深度分页方式 fro ...
- 工具-VS2015前端开发工具简介
每个涉及的工具库都给出了入门介绍.基本概念,以及在VS和ASP.NET中的用法.这个白皮书完全就是一个非常难得的前端开发入门手册. 具体涉及到的工具库有: 流行的JS任务执行器:Grunt和Gulp. ...
- 洛谷—— P2668 斗地主
https://www.luogu.org/problem/show?pid=2668 题目描述 牛牛最近迷上了一种叫斗地主的扑克游戏.斗地主是一种使用黑桃.红心.梅花.方片的A到K加上大小王的共54 ...
- UML基本架构建模--获取类
Getting Started 開始 Modeling a system involves identifying the things that are important to your p ...
- ASP.NET—011:JavaScript报错常见问题
相信大家都写过JavaScript.JS由于语法以及自己须要实现的业务的原因,可能在一个页面上要写长篇大论.或者单独写js文件写了好几百K.JS不可否认给Web编程带了很多的方便. 可是假设JS发生了 ...
- [Android]RecyclerView的简单演示样例
去年google的IO上就展示了一个新的ListView.它就是RecyclerView. 下面是官方的说明,我英语能力有限,只是我大概这么理解:RecyclerView会比ListView更具有拓展 ...