python12day
昨日回顾
可迭代对象:
- 可以更新迭代的实实在在的值。
- 内部含有
'__iter__'方法。 - str、tuple、dict、set、range
- 优点:操作方法多,灵活直观
- 缺点:占用内存。
迭代器:
- 可以更新迭代的一个工具(数据结构)
- 内部含有
'__iter__'并且含有'__next__'方法。 - 文件句柄
- 优点:节省内存,惰性机制
- 缺点:不直观,速度相对慢,操作方法单一,不走回头路。
格式化输出
函数名的运用:就是个变量
作用域的坑
练习题
#看代码写结果
def func1():
print('in func1') def func2(x):
print('in func2')
return x def func3(y):
print('in func3')
return y ret=func2(func1)
ret()
ret2=func3(func2)
ret3=ret2(func1)
ret3()
'''
in func2
in func1
in func3
in func2
in func1
'''
#看代码写结果
def func():
for item in range(10):
pass
print(item)
func()
'''
9
'''
#看代码写结果
l1=[]
def func4(args):
l1.append(args)
return l1
print(func4(1))
print(func4(2))
print(func4(3))
'''
[1]
[1,2]
[1,2,3]
'''
#写函数计算阶乘
def cal(num):
count=1
for i in range(num,0,-1):
count = count * i
return count
print(cal(3))
今日内容
生成器
#吃包子,5000个,函数剩下没吃完不好算
def func1():
l1=[]
for i in range():
l1.append(f'{i}号包子')
return l1
ret=func()
print()#就是个可迭代对象 #吃包子,吃一个做一个,生成器
def gen_func1():
for i in range(1,5001):
yield f'{i}号包子'
ret=gen_func1()
for i in range(200):
print(next(ret)) ##next一次做一个包子
#就是个迭代器
什么是生成器:生成器和迭代器可以看作一种,生成器的本质就是迭代器。
生成器迭代器区别:生成器是我们自己用python代码构建的数据结构。而迭代器都是提供或转换来的。
获取方式
生成器函数
#以往见到的函数
def func():
print(111)
print(222)
return 3
ret=func()
print(ret)
'''
111
222
3
''' #生成器函数
def func():
print(111)
print(222)
yield 3
yield 4
yield 5
ret=func()
print(ret) #<generator object func at 0x000002B0868AB0F8>
print(next(ret)) #一个next对应一个yield
# 111
# 222
# 3
print(next(ret)) # 4
print(next(ret)) # 5
生成器表达式
python内部提供的一些
yield
yield、return对比
- yield:函数中有yield就一定式生成器函数而不是函数了。生成器函数可存在多个yield,yield不结束生成器函数。
- return:函数中只存在一个return,结束函数返回值。
yield from
#yield from
def func2():
l1=[1,2,3,4,5]
yield from l1
##这样会从列表中拿出单一的元素,将l1这个列表变成了一个迭代器
ret=func2()
print(next(ret))
生成器表达式、列表推导式
列表推导式:用一行代码构建一个比较复杂有规律的列表。
l1=[i for i in range(1,11)]
列表推导式分两类:
循环模式:
[变量(加工后的变量)for 变量 in iterable]筛选模式:
#30以内能被3整除的数
l1=[i for i in range(1,31) if i%3==0]
#过滤长度小于3的字符串列表,并将剩下的转换成大写
l1=['sadjiwqf','sd','a','dqwdj','asd','wqewr','henri']
print([i.upper() for i in l1 if len(i)>=3])
生成器表达式:与列表推导式的写法几乎一样,把[]变成()就变成了生成器表达式,非常节省内存,也有筛选模式和循环模式。
obj=(i for i in range(1,11))
next(obj)
小结:
列表推导式:
缺点:有毒,列表推导式只能构建比较有规律的列表。超过三层循环才能构建成功的不建议用,另外debug模式查找错误不行。
优点:简单、装逼。
#装逼
#构建一个列表[2,3,4,5,6,7,8,9,10,'J','Q','K','A']
l1=[i for i in range(2,11)]+list('JQKA')
print(l1)
列表推导式与生成器表达式区别
- 写法上:[],()
- iterable、iterator
(了解)还有字典推导式、集合推导式,都是一行构建
内置函数I
python提供了68个内置函数
今天的这部分大部分了解即可。
eval()剥去字符串的外衣,运算里面的代码。最好不要使用
#eval
s1='1+3'
print(eval(s1)) #4
exec():与eval()几乎一样,但是是处理代码流的。
hash():获取一个对象的哈希值。int str bool等
help():获取对象的使用方法
callable():判断对象是否可调用
今日总结
- 生成器:我们用python代码自己构建的
- 生成器函数yield
- yield与return区别、yield from
- 列表推导式、生成器表达式
- 内置函数:学了一些了解即可的
明天学习
- lambda表达式
- 内置函数II
- 闭包
代码总行数1752+135=1887行
python12day的更多相关文章
随机推荐
- 【LeetCode】553. Optimal Division 解题报告(Python & C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ...
- CODEFORCEs 621E. Wet Shark and Blocks
E. Wet Shark and Blocks time limit per test 2 seconds memory limit per test 256 megabytes input stan ...
- 「算法笔记」Polya 定理
一.前置概念 接下来的这些定义摘自 置换群 - OI Wiki. 1. 群 若集合 \(s\neq \varnothing\) 和 \(S\) 上的运算 \(\cdot\) 构成的代数结构 \((S, ...
- Jmeter环境变量配置你不得不知道的事情
在安装Jmeter的过程中大家肯定需要配置环境,但是为什么要配置JDK的环境变量呢?大家有没有好奇过,有没有仔细去像一下呢,其实在安装Jmeter前,大家应该都知道Jmeter是我们JAVA开发的,J ...
- Capstone CS5213|HDMI转VGA|CS5213设计参考电路
Capstone CS5213是一款HDMI到VGA转换器结合了HDMI输入接口和模拟RGB DAC输出且带支持片上音频数模转换器.CS5213芯片设计简单,整体芯片尺寸精悍,外围电路集成优化度较高, ...
- JavaScript交互式网页设计作业目录(作业笔记)
JavaScript交互式网页设计笔记 • [目录] 我的大学笔记>>> 第1章 JavaScript基本语法>>> 1.1.4 使用 JavaScript 的 H ...
- MySQL创建数据库 easyShopping,包括area表、goods表、customer表、orders表、ordersdetall表、test表
MySQL创建数据库 easyShopping,包括area表.goods表.customer表.orders表.ordersdetall表.test表 商品表表结构: 字段名 说 明 类 型 长 度 ...
- 教你如何6秒钟往MySQL插入100万条数据!然后删库跑路!
教你如何6秒钟往MySQL插入100万条数据!然后删库跑路! 由于我用的mysql 8版本,所以增加了Timezone,然后就可以了 前提是要自己建好库和表. 数据库test, 表user, 三个字段 ...
- 使用tomcat搭建HTTP文件下载服务器
使用tomcat搭建HTTP文件下载服务器, 有时我们的应用或者服务需要去外网下载一些资源, 但是如果在内网环境或者网络不好的情况下, 我们可以在内网提供文件下载服务, 将预先下载好的资源放在某个地方 ...
- 关于ActiveMQ+Zookeeper做集群时,解决启动报错:java.io.IOException: com/google/common/util/concurrent/internal/InternalFutureFailureAccess
这个问题我也是无意间碰到的,之前一直是使用单机的ActiveMQ,所以也没这个问题,但是做集群时碰到这个问题,问题是这样子出现的: 首先,我准备了三台虚拟机,然后使用 Replicated Level ...