day6学python 生成器迭代器+压缩文件
生成器迭代器+压缩文件
readme的规范
1软件定位,软件的基本功能
2运行代码的方法:安装环境,启动命令
3简要的使用说明
4代码目录结构说明,更详细点可以说明软件的基本原理
5常见问题说明
========================================================
列表生成器
[i*2 for i in range(10)] #开头的可为函数也可为方程
已经在内存中生成 存在并可调用
==========================================================
生成器:generator(有yield关键词存在 就是生成器)
1.一边循环一边计算的机制
2.循环到时才能使用
3.只记录当前位置
a=(i*2 for i in range(10))
特点 :
1.在调用时只能用__next__()方法 一次次调用(用来唤醒yield)
2.不可像调用列表一样调用生成器
作用:
1.在运行循环时可进出自由 增加语句
##生成器并行##
import time
def maker(name):
c1=eater("a")
c2=eater("b")
c1.__next__()
c2.__next__()
print(name,"doing")
for i in range (10):
time.sleep(1)
print("第{}个".format(i+1))
c1.send(i)
c2.send(i)
def eater(name):
print(name,"eating=====")
while True:
baozi = yield
print("包子{}号来了,给{}吃了".format(baozi+1,name))
maker("cc")
===================================================================
可迭代对象和迭代器
1.可迭代对象:Iterable 可循环的对象(例:list,tuple,dict,set,str,生成器)
2.迭代器:Iterator可以被next()函数调用 不断返回下一个值的对象
3.生成器都是迭代器
4.列表字典字符串不是迭代器! 但可用iter(列表/字典/字符串)获得迭代器对象
==================================================================
内置方法(节选)
exec()执行字符串
a="print(\"hello\")"
exec(a)
eval(str)将字符串去掉“”(”蜕皮“)
eval("2+1")
结果:3
lambda作为匿名函数关键词
filter()从一组数据中过滤想要的
res1=filter(lambda n:n>5,range(10))
结果:6,7,8,9
map()对传入的数值进行处理后返回
res2=map(lambda n:2*n,range(10))
结果:0,2,4,6,8,10,12,14,16,18
zip() 将两个数组对应成元组 按少的来
a=[1,2,3,4,5]
b=["a","b","c"]
for i in zip(a,b):
print(i)
结果:(1, 'a') (2,'b') (3,'c')
返回当前目录的相对路径
print(__file__)
os.path.abspath(文件)#返回当前目录的绝对路径
import os
print(os.path.abspath(__file__))
os.path.dirname(“路径”)返回去文件名的绝对路径(返回当前文件上级)
a=os.path.dirname(os.path.abspath(__file__))
import sys
print(sys.path)
---恢复内容结束---
readme的规范
1软件定位,软件的基本功能
2运行代码的方法:安装环境,启动命令
3简要的使用说明
4代码目录结构说明,更详细点可以说明软件的基本原理
5常见问题说明
========================================================
列表生成器
[i*2 for i in range(10)] #开头的可为函数也可为方程
已经在内存中生成 存在并可调用
==========================================================
生成器:generator(有yield关键词存在 就是生成器)
1.一边循环一边计算的机制
2.循环到时才能使用
3.只记录当前位置
a=(i*2 for i in range(10))
特点 :
1.在调用时只能用__next__()方法 一次次调用(用来唤醒yield)
2.不可像调用列表一样调用生成器
作用:
1.在运行循环时可进出自由 增加语句
##生成器并行##
import time
def maker(name):
c1=eater("a")
c2=eater("b")
c1.__next__()
c2.__next__()
print(name,"doing")
for i in range (10):
time.sleep(1)
print("第{}个".format(i+1))
c1.send(i)
c2.send(i)
def eater(name):
print(name,"eating=====")
while True:
baozi = yield
print("包子{}号来了,给{}吃了".format(baozi+1,name))
maker("cc")
===================================================================
可迭代对象和迭代器
1.可迭代对象:Iterable 可循环的对象(例:list,tuple,dict,set,str,生成器)
2.迭代器:Iterator可以被next()函数调用 不断返回下一个值的对象
3.生成器都是迭代器
4.列表字典字符串不是迭代器! 但可用iter(列表/字典/字符串)获得迭代器对象
==================================================================
内置方法(节选)
exec()执行字符串
a="print(\"hello\")"
exec(a)
eval(str)将字符串去掉“”(”蜕皮“)
eval("2+1")
结果:3
lambda作为匿名函数关键词
filter()从一组数据中过滤想要的
res1=filter(lambda n:n>5,range(10))
结果:6,7,8,9
map()对传入的数值进行处理后返回
res2=map(lambda n:2*n,range(10))
结果:0,2,4,6,8,10,12,14,16,18
zip() 将两个数组对应成元组 按少的来
a=[1,2,3,4,5]
b=["a","b","c"]
for i in zip(a,b):
print(i)
结果:(1, 'a') (2,'b') (3,'c')
返回当前目录的相对路径
print(__file__)
os.path.abspath(文件)#返回当前目录的绝对路径
import os
print(os.path.abspath(__file__))
os.path.dirname(“路径”)返回去文件名的绝对路径(返回当前文件上级)
a=os.path.dirname(os.path.abspath(__file__))
import sys
print(sys.path)
---恢复内容结束---
readme的规范
1软件定位,软件的基本功能
2运行代码的方法:安装环境,启动命令
3简要的使用说明
4代码目录结构说明,更详细点可以说明软件的基本原理
5常见问题说明
========================================================
列表生成器
[i*2 for i in range(10)] #开头的可为函数也可为方程
已经在内存中生成 存在并可调用
==========================================================
生成器:generator(有yield关键词存在 就是生成器)
1.一边循环一边计算的机制
2.循环到时才能使用
3.只记录当前位置
a=(i*2 for i in range(10))
特点 :
1.在调用时只能用__next__()方法 一次次调用(用来唤醒yield)
2.不可像调用列表一样调用生成器
作用:
1.在运行循环时可进出自由 增加语句
##生成器并行##
import time
def maker(name):
c1=eater("a")
c2=eater("b")
c1.__next__()
c2.__next__()
print(name,"doing")
for i in range (10):
time.sleep(1)
print("第{}个".format(i+1))
c1.send(i)
c2.send(i)
def eater(name):
print(name,"eating=====")
while True:
baozi = yield
print("包子{}号来了,给{}吃了".format(baozi+1,name))
maker("cc")
===================================================================
可迭代对象和迭代器
1.可迭代对象:Iterable 可循环的对象(例:list,tuple,dict,set,str,生成器)
2.迭代器:Iterator可以被next()函数调用 不断返回下一个值的对象
3.生成器都是迭代器
4.列表字典字符串不是迭代器! 但可用iter(列表/字典/字符串)获得迭代器对象
==================================================================
内置方法(节选)
exec()执行字符串
a="print(\"hello\")"
exec(a)
eval(str)将字符串去掉“”(”蜕皮“)
eval("2+1")
结果:3
lambda作为匿名函数关键词
filter()从一组数据中过滤想要的
res1=filter(lambda n:n>5,range(10))
结果:6,7,8,9
map()对传入的数值进行处理后返回
res2=map(lambda n:2*n,range(10))
结果:0,2,4,6,8,10,12,14,16,18
zip() 将两个数组对应成元组 按少的来
a=[1,2,3,4,5]
b=["a","b","c"]
for i in zip(a,b):
print(i)
结果:(1, 'a') (2,'b') (3,'c')
返回当前目录的相对路径
print(__file__)
os.path.abspath(文件)#返回当前目录的绝对路径
import os
print(os.path.abspath(__file__))
os.path.dirname(“路径”)返回去文件名的绝对路径(返回当前文件上级)
a=os.path.dirname(os.path.abspath(__file__))
import sys
print(sys.path)
day6学python 生成器迭代器+压缩文件的更多相关文章
- python批量处理压缩文件
python批量处理压缩文件 博客小序:在数据的处理中,下载的数据很有可能是许多个压缩文件,自己一个一个解压较为麻烦,最近几日自己在处理一次下载的数据时,遇到大量的压缩数据需要处理,于是利用pytho ...
- Python脚本破解压缩文件口令(zipfile)
环境:Windows python版本2.7.15 Python中操作zip压缩文件的模块是 zipfile . 相关文章:Python中zipfile压缩文件模块的使用 我们破解压缩文件的口令也是用 ...
- Python中zipfile压缩文件模块的使用
目录 zipfile 压缩一个文件 解压文件 高级应用 利用 zipfile 模块破解压缩文件口令:Python脚本破解压缩文件口令 zipfile Python 中 zipfile 模块提供了对 z ...
- python 生成器 迭代器
阅读目录 一 递归和迭代 二 什么是迭代器协议 三 python中强大的for循环机制 四 为何要有for循环 五 生成器初探 六 生成器函数 七 生成器表达式和列表解析 八 生成器总结 一 递归和迭 ...
- python实现批量压缩文件夹
前段时间碰到一个需要把目录下文件夹压缩的项目,但是度娘里没找到,只好自己写脚本了. #coding:utf-8 import os filePath = raw_input("请输入路径:& ...
- 【Python】zlib压缩文件
import zlib import os ss = 's' * 1024 * 1024 #写入原始文件 file = open("src.dat", "wb" ...
- Python 生成器, 迭代器, 可迭代对象的区别
1.可迭代对象 在python中, 一切皆对象, 但凡是可以用for循环进行遍历取值的对象都可以称之为可迭代对象, 可迭代对象在程序的一个执行周期中,可以无限轮次的进行循环遍历 2.迭代器 a.一个可 ...
- python 生成器 迭代器 yiled
文章来源:http://python.jobbole.com/81911/ https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449 ...
- python生成器&迭代器
列表生成式 [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] 里每个值都加一 普通做法 a = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]for index,i in e ...
随机推荐
- 如何检测 51单片机IO口的下降沿
下降沿检测,说白了就是满足这样一个逻辑,上次检测是1,这次检测是0,就是下降沿. 从这个条件可知,要确保能够正确检测到一个下降沿,负脉冲的宽度,必须大于一个检测周期,当负脉冲宽度小于一个检测周期,就有 ...
- float型数据与字节数组的转化
float型数据与字节数组的转化 字节(float)浮点数为例. 一.C语言 转化常见的方法有: 1.强制指针类型转换. [html] view plain copy //转换float数据到字节数组 ...
- Deep Learning 学习笔记(3):Linear Regression 数据的预处理
为了获得良好的收敛,在进行梯度下降前,我们可以对数据进行预处理. 目标是使得数据大小在同一个数据数量级上,均值为零. 一般将数据放缩到(-1,1)区间, 我们可以对数据进行如下操作: 其中u1是数据的 ...
- Python——通过斐波那契数列来理解生成器
一.生成器(generator) 先来看看一个简单的菲波那切数列,出第一个和第二个外,任意一个数都是由前两个数相加得到的.如:0,1,1,2,3,5,8,13...... 输入斐波那契数列前N个数: ...
- leetcode582
public class Solution { public IList<int> KillProcess(IList<int> pid, IList<int> p ...
- 有关DNS
单位的域控制器和下面客户端的连接一直有问题,时常会找不到服务器连接: 错误基本显示为:没有可以登录的服务器 无法连接seed.com域 后来发现,是DNS解析的问题,单位使用了外部解析地址202.96 ...
- 数据仓库-数据采集-ETL漫谈
数据仓库之ETL漫谈ETL,Extraction-Transformation-Loading的缩写,中文名称为数据抽取.转换和加载.大多数据仓库的数据架构可以概括为:数据源-->ODS(操作型 ...
- tomcat报503 或者无法启动应用
一般都是配置文件有问题,或者路径问题,或者jvm的参数路径问题.... 总之,报错实在是不清楚!这点比resin差远了!!
- 在aspx页动态加载ascx页面内容,给GridView控件绑定数据
在aspx页动态加载ascx页面内容 //加载ascx页面内容Control c1 = this.Page.LoadControl("WebUserControl1.ascx"); ...
- memcache 随笔
第一次用可能有很多不足的地方 以后慢慢改进. memcache 是一个简单的键/值对 是通过键和值储存信息到memcache中 ,通过特定的键请求来返回信息. 信息会无限期的保留在内存中 : ...