函数进阶(三) day14
目录
昨日内容
迭代器
迭代器对象一定是可迭代对象,可迭代对象不一定是迭代器对象
可迭代对象
含有__iter__
的方法的数据类型
除了数字类型都是可迭代对象
迭代器对象
含有__iter__
和__next__
方法的数据类型
只有文件是迭代器对象
可迭代对象加上__iter__
就是迭代器对象
for循环原理
lt = [1,2]
lt_iter = lt.__iter__()
while True:
try:
print(lt_iter.__next__())
except StopIteration as e:
break
三元表达式
条件成立 if条件 else 条件不成立
列表推导式
[i for i in range(10)]
字典生成式
{i:i for i in range(10)}
zip
把多个可迭代对象一次性读取每一个可迭代对象种的元素,拼成元素
生成器表达式
(i for i in range(10))
节省空间
生成器
本质是迭代器,自定义迭代器,含有yield关键字的函数
def ge():
yield
yield
- 暂停函数
- 通过next取出一个yield的值
递归
函数调用函数本身,有退出条件
count = 0
def a():
global count
print(count)
if count = 100:
return
count += 1
a()
今日内容
匿名函数
lambda 参数:<代码块>
匿名函数一般不单独使用,和filter()/map()/sorted()/列表的sort()内置方法连用
sort/max /min
内置方法是原值排序
salary_dict = { 'nick':2000, 'wick':3000, 'jason':5000, 'egom':10000 } # 按照薪资排序 salary_list = list(salary_dict.items()) # 方法1 def func(i): return i[1] salary_list.sort(key=func) print(salary_list) # 方法2 salary_list.sort(key=lambda i:i[1]) print(salary_list)
sorted
重新创建一个新的列表排序
salary_list = sorted(salary_list,key=lambda i:i[1],reverse = True)
filter过滤筛选(迭代器)
判断匿名函数的返回值的真假,真则留下
print(list(filter(lambda i:i[1] > 5000,salary_list))) # [('egom':10000)]
map绘制/映射
匿名函数的返回值是map()的结果之一
print(list(map(lambda i:i[1]+2000,salary_list))) # [4000,5000,7000,12000]
内置方法
掌握
bytes 转换二进制串
bytes('中国',encoding = 'utf8')
chr/ord
print(chr(97)) # a print(ord('a')) # 97
divmod
print(divmod(10,4)) # 取整/取余
enumerate
lt = [1,2,3] for i,j in enumerate(lt): print(i,j) # 索引/值
eval 把字符串的引号去掉,留下的是什么就是什么
s = '[1,2,3]' print(eval(s)) # [1,2,3] type:str
hash 可变不可哈希
print(hash(1)) # 判断是否可哈希,可哈希返回原值,否则报错
了解
方法 | 作用 |
---|---|
abs | 绝对值 |
all | 如果全为真则为True,否则为False |
any | 只有有一个为真,则为真,否则为假 |
bin | 转换为二进制 |
oct | 八进制 |
hex | 十六进制 |
dir | 列出模块所有方法 |
frozenset | 不可变集合 |
globals/loals | 列出所有全局变量/当前位置所有变量 |
pow | 幂 |
round | 四舍五入 |
slice | 切片 |
sum | 求和 |
__import__ | 通过字符串导入模块 |
异常处理
只能捕捉逻辑错误
try:
代码
except Exception as e: # 万能异常
print(e) # 错误描述
代码
finally:
代码 # 无论报错与否,最终都会执行
assert 断言
assert 条件
assert 1 == 1 # 不做处理
assert 1 == 2 # 报错
raise 主动抛出错误
内置方法使用
面向过程编程(思想)
IPO编程 == 面向过程编程
面向过程编程:类似于流水线,一一步一步的往下走
优点:逻辑非常清晰
缺点:上一步错了,下一步跟着错
函数进阶(三) day14的更多相关文章
- Python进阶(三)----函数名,作用域,名称空间,f-string,可迭代对象,迭代器
Python进阶(三)----函数名,作用域,名称空间,f-string,可迭代对象,迭代器 一丶关键字:global,nonlocal global 声明全局变量: 1. 可以在局部作用域声明一 ...
- Java进阶(三十六)深入理解Java的接口和抽象类
Java进阶(三十六)深入理解Java的接口和抽象类 前言 对于面向对象编程来说,抽象是它的一大特征之一.在Java中,可以通过两种形式来体现OOP的抽象:接口和抽象类.这两者有太多相似的地方,又有太 ...
- Java进阶(三十四)Integer与int的种种比较你知道多少?
Java进阶(三十四)Integer与int的种种比较你知道多少? 前言 如果面试官问Integer与int的区别:估计大多数人只会说到两点:Ingeter是int的包装类,注意是一个类:int的初值 ...
- 【python 3】 函数 进阶
函数进阶 1.函数命名空间和作用域 命名空间一共分为三种: 全局命名空间 局部命名空间 内置命名空间 *内置命名空间中存放了python解释器为我们提供的名字:input , print , str ...
- day11.1函数进阶 列表集合 字典中的函数变量,函数作为形参
函数进阶 1.函数作为变量 a=123 name="gao" nums=[1,2,3] data=nums#指向同一个内存地址 #查看内存地址篇章 def func(): prin ...
- python基础 (初识函数&函数进阶)
函数基础部分 .什么是函数? 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率. 2.定义函数 定义:def 关键词开头,空格之后接函数名 ...
- day 10 - 1 函数进阶
函数进阶 命名空间和作用域 命名空间 命名空间 有三种内置命名空间 —— python解释器 就是python解释器一启动就可以使用的名字存储在内置命名空间中 内置的名字在启动解释器的时候被加载进内存 ...
- python基础之 初识函数&函数进阶
函数基础部分 1.什么是函数? 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段.函数能提高应用的模块性,和代码的重复利用率. 2.定义函数 定义:def 关键词开头,空格之后接函数名 ...
- python大法好——递归、内置函数、函数进阶
1.递归(自己干自己) def fun(n): n=n/2 print(n) if(n>2) fun(n) #函数调用 fun(10) 结果是5 2 1 0 递归的执行过程:递归执行到最里面一层 ...
随机推荐
- 手把手教你用最简便的方法免费安装SSL
原文链接:小枫同学的个人博客 随时IT的发展,它几乎涵盖了世界发展中的任何一方面,几乎都和计算机挂钩,也有好多小伙伴想开一个自己的网站,分享一些知识,分享一些心情等等.但是随着IT的发展,网络安全也越 ...
- Jmeter日记,很乱很随意
这个笔记是写给自己看的,很乱很随意,可能以后自己都看不懂.哈哈 Jmeter两种录制方式: 1使用badboy 2.使用代理 浏览器设置代理 参数化 随机参数化 插件的使用 官网下载和说明https: ...
- helm部署Filebeat + ELK
helm部署Filebeat + ELK 系统架构图: 1) 多个Filebeat在各个Node进行日志采集,然后上传至Logstash 2) 多个Logstash节点并行(负载均衡,不作为集群),对 ...
- SpringCloudEureka入门
说明 SpringBoot版本 2.1.7.RELEASE SpringCloud版本 Greenwich.SR2 创建eureka server工程 加入pom依赖 <dependencies ...
- linux 设置查看文本行数
在一般模式下,即摁下esc按键下的模式: 设置行数为:set nu(此处的冒号需要带上) 取消行号为:set nonu(此处的冒号需要带上)
- RocketMQ初入门踩坑记
本文主要是讲在Centos中安装RocketMQ并做简单的示例.如果你按照本文安装100%是可以成功的,如果按照阿里官方的说明,那只能呵呵了~ 安装 官方地址为:https://rocketmq.ap ...
- 【算法随记五】使用FFT变换自动去除图像中严重的网纹。
这个课题在很久以前就已经有所接触,不过一直没有用代码去实现过.最近买了一本<机器视觉算法与应用第二版>书,书中再次提到该方法:使用傅里叶变换进行滤波处理的真正好处是可以通过使用定制的滤波器 ...
- Nginx负载均衡配置实例
面对高并发的问题,企业往往会从两个方面来解决.其一,从硬件上面,提升硬件的配置,增加服务器的性能:另外,就是从软件上,将数据库和WEB服务器分离,使数据库和WEB服务器都能够充分发挥各自的性能,并且二 ...
- Android自动跳过app开屏广告
跳过开屏广告,体验流畅人生 开屏广告 是应用启动时显示的广告,一般右下角(或右下角)有倒计时跳过,不主动点击就会 等待3到5秒 后再进入App 自动跳过 是跳过应用的开屏广告的App 一图胜千文,来我 ...
- Redis面试篇 -- Redis主从复制原理
Redis一般是用来支撑读高并发的,为了分担读压力,Redis支持主从复制.架构是主从架构,一主多从, 主负责写,并且将数据复制到其它的 slave 节点,从节点负责读. 所有的读请求全部走从 ...