day13. 迭代器与高阶函数】的更多相关文章

一.迭代器 """ 能被next调用,并不断返回下一个值的对象,叫做迭代器(对象) 概念: 迭代器指的是迭代取值的工具,迭代是一个重复的过程,每次重复都是基于上一次的结果而继续的, 单纯的重复并不是迭代 特征: 并不依赖索引,而通过next指针迭代所有数据,一次只取一个值,大大节省空间 """ 1.可迭代对象 setvar = {"a","b","c","d"} fo…
一.匿名函数 lambda表达式 用一句话来表达只有返回值的函数,叫匿名函数特点:简洁方便语法:lambda 参数: 返回值 1.不带有参数的lambda表达式 def func():    return "今天要下雨,天气挺冷" #定义一个lambda表达式func = lambda : "今天要下雨,天气挺冷"res = func()print(res) 2.带有参数的lambda表达式 def func(n):    return type(n) func =…
1.迭代器 # ### 迭代器 """能被next调用,并不断返回下一个值的对象""" """ 特征:迭代器会生成惰性序列,它通过计算把值依次的返回,一边循环一边计算而不是一次性得到所有数据 优点:需要数据的时候,一次取一个,可以大大节省内存空间.而不是一股脑的把所有数据放进内存. """ # 1.可迭代对象 """ 如果一个数据类型其中的成员包含了__it…
迭代器 迭代器是访问集合元素的一种方式,迭代器从对象的第一个元素开始访问,知道所有元素被访问完成.迭代器只能往前访问,不能通过索引访问. 类型内部使用__iter__()方法转为迭代器,使用__next__()取值. 特点: 访问者不需要关心迭代器内部的结构,仅需通过next()方法不断去取下一个内容 不能随机访问集合中的某个值 ,只能从头到尾依次访问 访问到一半时不能往回退 便于循环比较大的数据集合,节省内存 迭代器协议 对象必须提供一个__next__方法执行该方法要么返回迭代中的下一项,要…
1. 迭代器与可迭代对象 # ### 迭代器 """ 迭代器: 能被next方法调用,并且不断返回下一个值的对象,是迭代器(对象) 特征:迭代器会生成惰性序列,它通过计算把值依次的返回,一边循环一边计算而不是一次性得到所有数据 优点:需要数据的时候,一次取一个,可以大大节省内存空间.而不是一股脑的把所有数据放进内存. 总结: 1.惰性序列,节省内存空间 2.遍历获取值得时候使用next,方向不可逆 3.迭代器可以遍历无限量大的数据 """ # 可…
Python3高阶函数之迭代器.装饰器 列表生成式 推导式就是构建比较有规律的列表,生成器. 孩子,我现在有个需求,看列表[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],我要求你把列表里的每个值加1,你怎么实现?你可能会想到2种方式 屌丝青年版 a=[0,1,2,3,4,5,6,7,8,9] b=[] for i in a:b.append(i+1) print(b) print(a) # 输出结果为 [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] [0, 1, 2…
高阶函数概念 first class object:     函数在python中时一等公民.     函数也是对象,可调用的对象.     函数可以作为普通变量,参数,返回值等等. 高阶函数:     数学概念: y=g(f(x)).     在数学和计算机科学中,高阶函数应当是至少满足下面一个条件的函数:     接受一个或多个函数作为参数.     输出一个函数. 计数器: def counter(base): def inc(step=1): base += step return ba…
1.全局变量和局部变量 一般定义在程序的最开始的变量称为函数变量,在子程序中定义的变量称为局部变量,可以简单的理解为,无缩进的为全局变量,有缩进的是局部变量,全局变量的作用域是整个程序,而局部变量的作用域是子程序内部,当程序运行时,首先会找程序内部有没有局部变量,如果有,则调用,如果没有,才会去调用全局变量.如下: name="czp" #全局变量 def func(): name="czp1" #局部变量 print(name) func() 运行结果: czp1…
1.全局变量和局部变量 一般定义在程序的最开始的变量称为函数变量,在子程序中定义的变量称为局部变量,可以简单的理解为,无缩进的为全局变量,有缩进的是局部变量,全局变量的作用域是整个程序,而局部变量的作用域是子程序内部,当程序运行时,首先会找程序内部有没有局部变量,如果有,则调用,如果没有,才会去调用全局变量.如下: name="czp" #全局变量 def func(): name="czp1" #局部变量 print(name) func() 运行结果: czp1…
什么是高阶函数?把函数作为参数传入或把函数做为结果值返回,这样的函数称为高阶函数,函数式编程就是指这种高度抽象的编程范式.函数式编程的特点: 函数本身可以赋值给变量,赋值后变量为函数: 允许将函数本身作为参数传入另一个函数: 允许返回一个函数. 在前面的章节中,我们知道可以用abs()这个函数来得到一个数的绝对值,如: print('abs(-100):', abs(-100)) 以上代码,输出: abs(-100): 100 如果,我们把代码修改下,把abs赋值给一个变量: f = abs p…
新闻 管理   Py西游攻关之函数   一 函数是什么? 函数一词来源于数学,但编程中的「函数」概念,与数学中的函数是有很大不同的,具体区别,我们后面会讲,编程中的函数在英文中也有很多不同的叫法.在BASIC中叫做subroutine(子过程或子程序),在Pascal中叫做procedure(过程)和function,在C中只有function,在Java里面叫做method. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但你也可以自…
匿名函数 python定义一个函数通常使用def关键词,后面跟函数名,然后是注释.代码块等. def func(): '''注释''' print('from func') 这样就在全局命名空间定义了一个叫func的函数,func表示函数体的内存地址,因为func指向函数体内存地址,所以可以通过func来调用函数. 那么匿名函数呢?从名字就可看出,匿名.想想就有点像以前小时候的佚名一样,带点说不清楚的神秘色彩,现在想来之所以感觉神秘可能是因为那时候不认识''佚''这个字... 强调: 匿名函数的…
高阶函数:1.  函数名是一个变量,函数名可以进行赋值 2. 函数名可以作为函数参数,还可以作为函数返回值(函数名称作为函数返回值时返回的是:函数的地址:print 这个返回值的调用相当于执行这个函数. 函数调用作为函数返回值相当于返回这个函数的执行结果) def f(n): return n*n def foo(a, b, func): return func(a)+func(b) print(foo(1, 2, f)) # >>> 5 递归函数: 调用自身函数 设置结束条件 每次进入…
能够把函数当成参数传递的参数就是高阶函数 map map: 功能: 拿iterable的每一个元素放入func中, func的返回值放入迭代器内进行返回 参数: iterable, func 返回: 迭代器 # ["a","c","b"] => [97,99,98] dictvar = {97:"a",98:"b",99:'c',100:'d',101:'e'} def func(x): print(…
高阶函数之:filter函数:过滤数据的,最终返回一个惰性序列对象(filter对象,迭代器对象)解释:filter的意思:在计算机领域中我们都称为过滤器格式:filter(fn,lsd):参数和map.reduce一样理解功能:将lsd中的每一个元素都给到fn函数如果fn函数的返回值为True,那么就保留这个元素到filter对象中如果fn函数的返回值为False,那么就舍弃这个元素,不会保留到filter对象中最终filter函数执行完毕了,返回给程序一个filter对象(迭代器对象) im…
1.高阶函数: 特点:函数的形参位置必须接受一个函数对象 分类学习: 1).map(fn,lsd1,[lsd2...]): 参数一:fn --> 函数对象 参数二:lsd1 --> 序列对象(字符串.列表.range...) 功能: 将fn函数作用于lsd1中的每一个元素上, 将每次执行的结果存入到一个map对象中返回: [注意]得到的这个map对象是一个迭代器对象 需求:lt = ['1','2','3','4','5'] --> [1,2,3,4,5] map(int,lt):执行过…
filter函数:filter()为已知的序列的每个元素调用给定的布尔函数,调用中,返回值为非零的元素将被添加至一个列表中 list = filter(调用函数名,可迭代对象)——调用函数名自动传参——可迭代对象的所有元素,返回非零元素被放入列表中 实例: cleaned_data = filter(is_convert_float,str_array) def is_convert_float(s): """ 判断字符串s能否转换为数字 :param s: :return:…
一.递归 在函数内部,可以调用其他函数.如果一个函数在内部调用自身本身,这个函数就是递归函数. 递归要求: 1. 必须有一个明确的结束条件 2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减少 3. 递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧.由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出) def calc(n): print(n) if…
接受函数作为参数,或者把函数作为结果返回的函数是高阶函数,官方叫做 Higher-order functions. map()和filter()是内置函数.在python3中,reduce()已不再是内置函数,被放到了functools模块里面,这个函数最常用于求和. 另外,列表推导式和生成器表达式具有map()和filter()两个函数的功能,而且更易于阅读. map() 在python3中,map()函数返回的是一个可迭代的map对象,可用list()函数转换为列表. map()函数将参数序…
python 函数式编程:高阶函数,map/reduce #函数式编程 #函数式编程一个特点就是,允许把函数本身作为参数传入另一个函数,还允许返回一个函数 #(一)高阶函数 f=abs f print(f(-20)) #结果 20 #函数可以赋值给一个变量,即:变量可以指向函数 #那么函数名是什么?函数名其实就是指向函数的变量! #下面的代码,执行后,abs已经不指向求绝对值函数而是一个整数10了. #后面的abs(-10)将报错,无法执行,必须重启python才可以. #abs=10 #abs…
匿名函数 描述:    关键字 lambda 定义的函数    语法: 函数名 = lambda 参数:返回值 返回值:    函数返回结果值 实例: 一个参数的匿名函数: func = lambda x: x*x f = func(2) print(f) # 执行结果: # 4 多个参数的匿名函数: func = lambda x, y: x+y f = func(1, 2) print(f) # 执行结果: # 3 高阶函数 (1)map 描述:    map()会根据提供的函数对指定序列做…
---------------个人学习笔记--------------- ----------------本文作者吴疆-------------- ------点击此处链接至博客园原文------ 1.集合 集合是无序的.不重复的数据组合,主要作用是:关系测试.去重等,用{}表示,set() 创建集合. --------------关系测试------------------------------ intersection() 求集合交集     运算符为 & union() 求集合并集   …
一. 高阶函数定义 简而言之,Python的高阶函数就是指一个函数作为参数传递给另外一个函数的用法. 举一个最简单的高阶函数来说明: >>> def add(x,y,f): return f(x) + f(y) >>> add(1,-2,abs) 3 可能会有同学问,直接return abs(x) + abs(y)不就完了么,何必这么麻烦. 我的理解是把函数作为参数传递,能够使得编码涉及上更具有灵活性,比如我们可以根据某些变量的不同,传入不同的函数进去,这样能使得代码更…
iterator:迭代器 python的iterator是一个惰性序列(即你不主动去遍历它,他不会去计算其中元素的值) m是一个iterator,所以通过tuple()函数让整个序列计算出来,并返回一个元组. def f(x): return x*x m = map(f,[1,2,3,4,5]) print(tuple(m)) map函数作为一个高阶函数,可以更快,更方便的对一些函数进行处理. map函数接受的函数作用于列表里的每个元素. print(list(map(str,[1,2,3,4,…
1 Python高阶函数 接收函数为参数,或者把函数作为结果返回的函数为高阶函数. 1.1 自定义sort函数 要求:仿照内建函数sorted,自行实现一个sort函数.内建函数sorted函数是返回一个新的列表,可以设置升序或降序,也可以设置一个排序的函数,自定义的sort函数也要实现这个功能. sort函数实现思路:新建一个列表,遍历原列表,和新列表的值一次比较决定如何插入到新列表中. sort函数版本一的实现,代码如下: def sort(iterable): ret = [] for x…
1.推导式:做一些有规律的数据结构 列表推导式: 普通循环模式: [加工后的变量 for 循环] 示例一:print([i for i in range(1,51)]) 结果:[1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43…
什么样的函数叫高阶函数: 条件:1.函数接受函数作为参数 2.函数的返回值中包含函数 高阶函数之----map函数 map(func, *iterables) --> map objectnum_l = [1,2,3,4,5,6]b = map(lambda x:x**2,num_l)print(b)for i in b: print(i)>>> <map object at 0x0000023023782358> #返回map对象,是迭代器 1 4 9 16 25 3…
什么样的函数叫高阶函数:map(func, *iterables) --> map object 条件:1.函数接受函数作为参数 2.函数的返回值中包含函数 num_l = [1,2,3,4,5,6]b = map(lambda x:x**2,num_l)print(b)for i in b: print(i)>>> <map object at 0x0000023023782358> #返回map对象,是迭代器 1 4 9 16 25 36 num_l = [1,2,…
Python入门篇-高阶函数 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.高级函数  1>.First Class Object 函数在Python中是一等公民 函数也是对象,可调用的对象 函数可以作为普通变量,参数,返回值等等 2>.高阶函数 数学概念:y=g(f(x)) 在数学和计算机科学中,高阶函数应当是至少满足下面一条条件的函数 接收一个或多个函数作为参数 输出一个函数对象 3>.计数器 #!/usr/bin/env python #_*_coding:…
高阶函数 First Class Object 函数在python中是一等公民 函数也是对象,可调用的对象 函数可作为普通变量.参数.返回值等等 高阶函数 数学概念 y=g(f(x)) 在数学和计算机科学中,高阶函数应当是至少满足下面一个条件的函数 接受一个或多个函数作为参数 输出一个函数 自定义sort函数 排序问题 仿照内建函数sorted,请自行实现一个sort函数.能够为序列元素排序 思路 内建函数sorted函数返回一个新的列表,可以设置升序或降序,可以设置一个排序的函数.自定义函数也…