Python之路,Day10 = Python基础10

生成器表达式: (i for i in range(10) if i > 5)
os.walk(r'文件路径')
返回一个迭代器,
  第一次next:包含一个元组,元组中有三个元素,(路径,路径包含的所有文件夹,路径包含的所有文件)
  第二次next:包含一个元组,元组中有三个元素,(上面第二个元素中的第一个路径,前面那个路径包含的所有文件夹,前面那个路径包含的所有文件)

1.x = yield #yield的表达式的应用,可以通过 yield 向函数中传值

 def yield_init(func):
def wrapper(*args,**kwargs):
res = func(*args,**kwargs)
next(res)
return res
return wrapper @yield_init
def eater(name):
baozi_l = []
while True:
food = yield baozi_l
baozi_l.append('包子%s'%food)
print('%s 吃 包子%s'%(name, food)) a = eater('LiSi')
for i in range(1,19):
print(' '.join(a.send(i)))

2.面向过程编程: grep -rl 'root' /etc

通过 yield 以及,函数,实现上面的命令(寻找到传入的路径下及自路径下的所有文件中包含 ‘roo’ 的文件的全路径,综合yield 及函数传值)

 #! /usr/bin/env python
# -*- coding: utf-8 -*-
# __author__ = "Always"
# Date: 2017/6/19 import os def yiled_init(func):
"""
装饰器,用来初始化 生成器(含有yield的函数),执行后立即执行next()方法。
:param func: 被装饰的 生成器
:return:
"""
def wrapper(*args,**kwargs):
res = func(*args, **kwargs)
next(res)
return res
return wrapper @yiled_init
def search(target):
"""
这里面用了一个 os.work() 函数,作用是递归进入所有的目录,并返回结果,结果为一个列表(当前目录,当前目录存在的所有文件夹, 当前目录存在的所有文件名)
:param target: 下一个函数的结果,用来将这个函数处理好的东西(文件名)传给它,进行下一步运算
:return:
"""
while True:
start_path = yield
g = os.walk(start_path)
for par_dir, _, files in g:
for file in files:
file_path = r'%s\%s'%(par_dir, file)
target.send(file_path) @yiled_init
def opener(target):
"""
用来打开文件
:param target: 下一个函数的结果,用来将这个函数处理好的东西(文件句柄)传给它,进行下一步运算
:return:
"""
while True:
file_path = yield
with open(file_path,encoding='utf-8') as f:
target.send((file_path, f)) @yiled_init
def cat(target):
"""
读取文件内容,逐行传给下一个函数,在下一个函数中寻找是否存在需要的内容,如果不存在就下一行,如果存在则返回True,终止这个文件循环
:param target: 下一个函数的结果,用来将这个函数处理好的东西(文件的行)传给它,进行下一步运算
:return:
"""
while True:
file_path, f = yield
for line in f:
if target.send((file_path, line)):
break @yiled_init
def grep(target, pattern):
"""
查找这行是否存在需要的内容,如果存在,传给下一个函数来打印,如果不存在,则忽略
:param target: 下一个函数的结果,用来将这个函数处理好的东西(文件全路径)传给它,进行下一步运算
:param pattern: 查找的关键字
:return:
"""
tag = False
while True:
file_path, line = yield tag
if pattern in line:
target.send(file_path)
tag = True @yiled_init
def printer():
"""
将传来的内容打印出来
:return:
"""
while True:
filename = yield
print(filename) filepath = r'C:\Users\Administrator\PycharmProjects\老男孩全栈5期\上课笔记\day'
g = search(opener(cat(grep(printer(), 'root'))))
g.send(filepath)

3.内置函数
       abs()             # 返回数字的绝对值。参数可以是整数或浮点数。如果参数是复数,则返回其大小。
  all()               # 括号中加入可迭代的对象,如果该对象的所有内容为 True,则返回True。如果可迭代对象为空,为 True。
  any()             # 括号中加入可迭代的对象,如果该对象的所有内容为 True,则返回True。如果可迭代对象为空,为 True。

  bin()      # 十进制转二进制
  oct()      # 十进制转八进制
  hex()     # 十进制转十六进制

day22 yield的表达式的应用,面向过程编程,内置函数前几个的更多相关文章

  1. Python开发基础-Day10生成器表达式形式、面向过程编程、内置函数部分

    生成器表达式形式 直接上代码 # yield的表达式形式 def foo(): print('starting') while True: x=yield #默认返回为空,实际上为x=yield No ...

  2. python基础之生成器表达式形式、面向过程编程、内置函数部分

    生成器表达式形式 直接上代码 1 # yield的表达式形式 2 def foo(): 3 print('starting') 4 while True: 5 x=yield #默认返回为空,实际上为 ...

  3. python之三元表达式与生成式与匿名与内置函数(部分)

    目录 三元表达式 各种生成式 列表生成式(可同样作用于集合) 字典生成式 匿名函数 重要内置函数 map() zip() filter() reduce() 常见内置函数(部分) 三元表达式 三元表达 ...

  4. python-迭代器、生成器、内置函数及面向过程编程

    一.迭代器 迭代器是迭代取值的工具,迭代是一个重复的过程,每一次重复都是基于上一次的结果而来的. 为什么要用迭代器呢? 1.可以不依赖索引取值 2.同一时刻在内存中只有一个值,不会过多的占用内存 如何 ...

  5. Python基础(9)_生成器(yield表达式形式)、面向过程编程

    一.yield表达式形式 1 #装饰器,初始化含yield表达式的生成器 def init(func): def wrapper(*args,**kwargs): g=func(*args,**kwa ...

  6. Python 迭代器-生成器-面向过程编程

    上节课复习:1. 函数的递归调用 在调用一个函数的过程中又直接或者间接地调用了函数本身称之为函数的递归 函数的递归调用有两个明确的阶段: 1. 回溯 一层一层地调用本身 注意: 1.每一次调用问题的规 ...

  7. yield的表达式形式与内置函数

    yield的功能: 1. 与return类似,都可以返回值,不一样在于,yield可以返回多个值而且可暂停,再次执行可继续下一步操作,return到了就停止不在继续运行. 2.为封装好的的函数能够使用 ...

  8. PYTHON-匿名函数,递归与二分法,面向过程编程

    """匿名函数1 什么是匿名函数 def定义的是有名函数:特点是可以通过名字重复调用 def func(): #func=函数的内存地址 pass 匿名函数就是没有名字的 ...

  9. python函数:匿名函数、函数递归与二分法、面向过程编程

    今天主要讲三大部分内容: 一.匿名函数二.函数递归与二分法三.面向过程编程 一.匿名函数: """ 1. 什么时匿名函数 def定义的是有名函数:特点是可以通过名字重复调 ...

随机推荐

  1. Apache版hadoop编译

    前言  做为大数据入门的基础,hadoop是每个大数据开发人员几乎不可避免的基础,目前hadoop已经发展到3.x.x版本,但当前企业使用的主流还是2.x.x版本,hadoop官网提供了编译后的had ...

  2. 从零开始学Jqueue

    http://www.cnblogs.com/zhangziqiu/archive/2009/04/30/jQuery-Learn-1.html

  3. 《代码大全2》读书笔记 Week3

    <代码大全2>第六.七章 作者在第六章中从抽象数据类型(Abstract Data Type)出发阐释类(class)的概念,给出创建类的原因以及创建高质量的常涉及的设计问题.抽象数据类型 ...

  4. SetupFactory 许可协议设置

    我用的SetupFactory版本是9.1.0 没有汉化 一开始自己也不知道 百度发现有人在问同样的问题但是没解决 自己找了一会偶然发现 界面左侧 Screens->Before Install ...

  5. whatis - 在 whatis 数据库里查找完整的单词

    总览 (SYNOPSIS) whatis keyword ... 描述 (DESCRIPTION) whatis 命令在一些特定的包含系统命令的简短描述的数据库文件里查找关键字, 然后把结果送到标准输 ...

  6. 笔记32 SpringMVC中使用静态资源、处理中文乱码

    一.静态资源的使用 在WebConfig.java中有如下代码段 @Override // 配置静态资源处理 public void configureDefaultServletHandling(D ...

  7. 链表vector

    根据逻辑次序的复杂程度,大致可以将各种数据结构划分为线性结构.半线性结构与非线性结构三大类. 在线性结构中,各数据项按照一个线性次序构成一个整体.最为基本的线性结构统称为序列(sequence),根据 ...

  8. <el-table>序号逐次增加,翻页时继续累加,解决翻页时从编号1开始的情况

    注释: scope.$index     当前序号 cuePage 表示当前页码 pageSize   表示每页显示的条数

  9. zmq的send

    int zmq_send (void *socket, zmq_msg_t *msg, int flags);      2.2.1 nt zmq_send (void *socket, void * ...

  10. Java标识符&关键字

    1. 标识符&关键字 [标识符]: Java 对各种变量.方法和类等要素命名时使用的字符序列称为标识符. 凡是自己可以起名字的地方都叫标识符 命名规则:(一定要遵守,不遵守就会报编译的错误) ...