生成器迭代器+压缩文件

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 生成器迭代器+压缩文件的更多相关文章

  1. python批量处理压缩文件

    python批量处理压缩文件 博客小序:在数据的处理中,下载的数据很有可能是许多个压缩文件,自己一个一个解压较为麻烦,最近几日自己在处理一次下载的数据时,遇到大量的压缩数据需要处理,于是利用pytho ...

  2. Python脚本破解压缩文件口令(zipfile)

    环境:Windows python版本2.7.15 Python中操作zip压缩文件的模块是 zipfile . 相关文章:Python中zipfile压缩文件模块的使用 我们破解压缩文件的口令也是用 ...

  3. Python中zipfile压缩文件模块的使用

    目录 zipfile 压缩一个文件 解压文件 高级应用 利用 zipfile 模块破解压缩文件口令:Python脚本破解压缩文件口令 zipfile Python 中 zipfile 模块提供了对 z ...

  4. python 生成器 迭代器

    阅读目录 一 递归和迭代 二 什么是迭代器协议 三 python中强大的for循环机制 四 为何要有for循环 五 生成器初探 六 生成器函数 七 生成器表达式和列表解析 八 生成器总结 一 递归和迭 ...

  5. python实现批量压缩文件夹

    前段时间碰到一个需要把目录下文件夹压缩的项目,但是度娘里没找到,只好自己写脚本了. #coding:utf-8 import os filePath = raw_input("请输入路径:& ...

  6. 【Python】zlib压缩文件

    import zlib import os ss = 's' * 1024 * 1024 #写入原始文件 file = open("src.dat", "wb" ...

  7. Python 生成器, 迭代器, 可迭代对象的区别

    1.可迭代对象 在python中, 一切皆对象, 但凡是可以用for循环进行遍历取值的对象都可以称之为可迭代对象, 可迭代对象在程序的一个执行周期中,可以无限轮次的进行循环遍历 2.迭代器 a.一个可 ...

  8. python 生成器 迭代器 yiled

    文章来源:http://python.jobbole.com/81911/ https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449 ...

  9. 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 ...

随机推荐

  1. Three.js创建运动立体几何体示例

    效果图 安装 帧率统计工具 变量控制GUI demo 效果图 安装 npm install three 帧率统计工具 // 监听动画帧率 var Stats = function () { var m ...

  2. Bind("入库日期", "{0:yyyy-MM-dd}") 关于asp.net格式化数据库日期字符串

    Bind("入库日期", "{0:yyyy-MM-dd}") 关于asp.net格式化数据库日期字符串,删除多余的000:0:00

  3. 【知识碎片】 Linuxb 篇

    3.登录mysql 开启MySQL服务后,使用MySQL命令可以登录.一般使用mysql -uroot -p即可.如果数据库不是本机,则需要加参数,常用参数如下:1,-h,指定ip地址,默认为loca ...

  4. SonarQube在CentOS上的安装

    1 简介 SonarQube 是一个用于代码质量管理的开放平台.通过插件机制,Sonar 可以集成不同的测试工具,代码分析工具,以及持续集成工具.与持续集成工具(例如 Hudson/Jenkins 等 ...

  5. bash shell笔记5 显示数据

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://twentyfour.blog.51cto.com/945260/521455 知 ...

  6. Unity3D自带Demo AngryBots路径

    [Unity3D自带Demo AngryBots路径] 1.Windows: C:\Users\Public\Documents\Unity Porjects 2.MacOSX: /Users/Sha ...

  7. Apache与Tomcat联系及区别

    Apache与Tomcat都是Apache开源组织开发的用于处理HTTP服务的项目,两者都是免费的,都可以做为独立的Web服务器运行.Apache是Web服务器而Tomcat是Java应用服务器. A ...

  8. c++之继承与派生

    再来回顾下继承派生的语法. 继承方式显示有三种(public, protected, privatez),隐式默认private.所谓继承方式,是指派生类对基类成员的访问权限控制. 派生类构造函数定义 ...

  9. 733. Flood Fill 简单型染色问题

    [抄题]: An image is represented by a 2-D array of integers, each integer representing the pixel value ...

  10. hibernate 一对一(级联关系)

    hibernate 核心配置文件 <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hiber ...