从入门到自闭之Python三大器--生成器
1.什么是生成器
- 核心:生成器的本质就是一个迭代器
- 迭代器是python自带的的
- 生成器是程序员自己写的一种迭代器
- 编写方式:
- 基于函数编写
- 推导式编写
def func ():
print("这是一个函数")
return“函数”
func()
def func():
print("这是一个生成器")
yield"生成器"
#func() 生成一个生成器
print(func().__next__) #启动生成器
输出结果:获取到的是一个生成器的
- 内存地址函数体中出现yield代表要声明一个生成器,generator -- 生成器
获取到的是一个生成器的内存地址
# 获取到的是一个生成器的内存地址
# <generator object func at 0x00000087C2A10CA8>
# def func():
# msg = input("请输入内容")
# yield msg
# print("这是第二次启动")
# yield "生成器2"
# yield "生成器3"
# yield "生成器4"
#
# g = func()
# print(next(g))
# print(next(g))
# print(next(g))
# print(next(g))
# 执行结果:
# 请输入内容>>>>你好
# 你好
# 这是第二次启动
# 生成器2
# 生成器3
# 生成器4
一个yield 必须对应一个next
# def func():
# lst =[]
# for i in range(100000):
# lst.append(i)
# return lst
# print(func())
# 输出结果:[0~100000]
用途:节省空间,例题:吃包子问题
使用场景:
- 当文件或容器中数据量较大时,建议使用生成器
可迭代对象:(python 3 )
- 优点:list,tuple,str 节省时间,取值方便,使用灵活(具有自己的私有办法)
- 缺点:消耗内存
迭代器:
- 优点:节省空间
- 缺点:不能直接查看值,使用不灵活,消耗时间,一次性,不可逆
生成器:
- 优点:节省空间,人为定义
- 缺点:不能直接查看值,消耗时间,一次性,不可逆行
yield 和 return 区别:
- 相同点
- 都是返回内容
- 都可以返回多次,但是return写多个只会执行一个
- 不同点
- return会终止函数,yield是暂停生成器
- yield能够记录当前执行位置
- 相同点
区别:通过send区别什么是迭代器,什么是生成器
迭代器的地址<list_iterator>
生成器的地址
# 数据类型 (pyhton3: range() | python2 :xrange()) 都是可迭代对象 __iter__()
# 文件句柄是迭代器 __iter__() __next__()
没有send方法就是一个迭代器,具有send方法就是一个生成器
# def func():
# lst = [1,2,3,45,6]
# lst1 = ["alex","wusir","taibi","baoyuan"]
# yield from lst
# yield from lst1
# g = func()
# print(g)
# 输出结果:<generator object func at 0x0000010DA038CF68>
yield from将可迭代对象逐个返回
yield 将可迭代对象一次性返回
2. 什么是推导式
- 列表推导式:
- 循环模式:([变量 for循环])
- print([i for i in range(10)])
- 筛选模式:[加工后的变量 for循环 加工条件]
- print ([i for i in range(10) if i > 2])
- print ([i for i in range(10) if i % 2 == 0])
- 循环模式:([变量 for循环])
- 集合推导式:
- 普通循环:{变量 for循环}
- print ({i for i in range(10)})
- 筛选模式:{加工后的变量for循环 加工条件}
- print({i for i in range (10) if i % 2 == 1})
- 普通循环:{变量 for循环}
- 字典推导式:
- 普通:{键:值 for循环}
- print {"key":"value" for i in range (10)}
- 筛选:{加工后的键:值 for循环 加工条件}
- print({i : i+1 for i in range(10) if i % 2 == 0})
- 普通:{键:值 for循环}
- 生成器推导式(面试必问):
- 普通模式:(变量 for 循环)
- tu = (i for i in range(10))这是生成器,切记
- 筛选模式:(加工后的变量 for 循环 加工条件)
- 普通模式:(变量 for 循环)
tu = (i for i in range(10)if i > 5)
for i in tu :
print(i)
3. 内置函数一:
eval:执行字符串类型的代码
exac:执行字符串社类型的代码
eval与exac 禁止使用
hash()作用就是区分可变数据类型与不可变数据类型
# print(hash("123"))
# print(hash(12))
# print(hash(-1))
# print(hash(-10))
# print(hash((2,1))) # dic = {[1,2,3]:2}
# print(hash([1,2,3]))help():查看帮助信息
callable():查看对象是否可以调用,
# def func():
# print(1)
# lst = [1,23,4,]
# print(callable(lst)) # 查看对象是否可调用int():将字符串或数字转换成整型
float():转换成浮点数
complex():复数
bin():十进制转二进制
oct():十进制转八进制
hex():十进制转十六进制
divmod():计算除数与被除数结果,包含一个商和余数的元祖
round():保留浮点数的小数位数,可以设定保留位数,默认保留整数
pow():求x ** y次幂(三个参数的时候为x ** y的结果对第三个参数取余)
bytes():用于不同编码之间的转换,建议使用encode
ord():通过元素获取当前表位编码位置
chr():通过表位序号查找对应的元素
repr():查看数据的原生态(给程序员使用的)
all():判断容器汇总的元素是否都为真,返回true
any():判断容器中的元素有一个为真,就是True
从入门到自闭之Python三大器--生成器的更多相关文章
- 从入门到自闭之python三大器--装饰器进阶
装饰器的进阶 有参装饰器: # def warpper(func): # def inner(*args,**kwargs): # user = input("user:") # ...
- 从入门到自闭之Python三大器--迭代器
函数名的第一类对象(概述): 使用方式: 函数名可以当做值赋值给变量 def func(): print(1) print (func) #查看函数的内存地址 a = func print (a) # ...
- 从入门到自闭之python三大器--装饰器
开放封闭原则:在不修改源代码及调用方式,对功能进行额外添加就是开放封闭原则 开放:对代码的扩展进行开发 封闭:修改源代码 装饰(额外功能) 器:工具(函数) 普通版: # print(time.tim ...
- Python 入门之 Python三大器 之 装饰器
Python 入门之 Python三大器 之 装饰器 1.开放封闭原则: (1)代码扩展进行开放 任何一个程序,不可能在设计之初就已经想好了所有的功能并且未来不做任何更新和修改.所以我们必须允许代 ...
- Python 入门之 Python三大器 之 生成器
Python 入门之 Python三大器 之 生成器 1.生成器 (1)什么是生成器? 核心:生成器的本质就是一个迭代器 迭代器是Python自带的 生成器程序员自己写的一种迭代器 def func( ...
- Python 入门之 Python三大器 之 迭代器
Python 入门之 Python三大器 之 迭代器 1.迭代器 (1)可迭代对象: <1> 只要具有__ iter __()方法就是一个可迭代对象 (我们可以通过dir()方法去判断一个 ...
- Python - 三大器 迭代器,生层器,装饰器
目录 Python - 三大器 迭代器,生层器,装饰器 一. 容器 二. 可迭代对象(iterable) 三. 迭代器 四. 生成器 五. 装饰器 1. 定义 六. 闭包 Python - 三大器 迭 ...
- 从入门到自闭之Python自定义模块
自定义模块 定义:一个文件就是一个模块(能被调用的文件,模块就是一个工具箱,工具就是函数) 作用: 将代码文家化管理,提高可读性,避免重复代码 拿来就用(避免重复造轮子),python中类库比较多,提 ...
- 从入门到自闭之Python 基础习题训练
""" name = input(">>>")通过代码来验证name变量是什么数据类型? """ na ...
随机推荐
- Work Queues(工作队列)
1.模型 2.创建生产者 package com.dwz.rabbitmq.work; import java.io.IOException; import java.util.concurrent. ...
- nmap脚本nse的使用
nmap脚本(nse)使用总结 0x01 nmap按脚本分类扫描 nmap脚本主要分为以下几类,在扫描时可根据需要设置--script=类别这种方式进行比较笼统的扫描: auth: 负责处理鉴权证书( ...
- 【java】获取项目资源路径
目资源路径分两种,一种是普通Java项目的资源路径,另一种是JavaEE项目的资源路径. 获取Java项目的包(源码下的包 或者 jar包)的资源路径 // 方法1:通过this.getClass() ...
- xcode6 如何编译64位iOS应用
原文:http://mobile.51cto.com/hot-412500.htm 随着iPhone5S的推出,大家开始关心5S上所使用的64位CPU A7. 除了关心A7的性能以外,大家还会关心一个 ...
- Java微信服务号的开发(简单入门)
进行微信服务号开发的步骤 一个别人已经搭建好的项目参考地址:下载链接 1.搭建微信服务号的服务器 项目配置maven <dependency> <groupId>com.soe ...
- 在.slurm文件中激活Anaconda环境
超算中心使用slurm作为集群调度.原始slurm脚本如下: source activate tensorflow-gpu python neural_style.py --content conte ...
- Android 使用date set命令修改系统时间
测试环境:android 7.1.1 在adb shell中试图使用 date -s "yyyymmdd.[[[hh]mm]ss]"修改系统系统时间时,会提示 date: Unkn ...
- [ASP.NET应用到的时间处理函数]
第一种形式: System.DateTime.Now.ToString("D"); //2017年6月2日 System.DateTime.Now.ToString ...
- Python 中的type和object详解
1.python中的类 Python2.x 中的类分为两种,一种是所有继承自object的新式类,另外一种是经典类classobj, 新式类的写法: class A(object): pass 经典类 ...
- 使用sql developer 导出Oracle数据库中的表结构
MS SQLServer的客户端工具做的的确比较好,直接右键,导出数据库就OK了,而且MS的客户端导出的是xxx.dbf文件,直接附加到别的数据库上就OK了 Oracle的sql developer就 ...