函数(二):input、raw_input、lambda、repr、map、filter、reduce、eval、exec、range、xrange
一、input()和raw_input():
input()支持用户输入数字或表达式,按类型存或存表达式的计算结果
raw_input():输入所有内容当成字符串存
二、lambda函数:匿名函数
lambda只是一个表达式,函数体比def简单的多
lambda的主体是一个表达式,而不是一个代码块。
lambda函数拥有自己的名字空间,且不能访问自由参数列表之外全局名字空间里的参数
lambda会返回一个函数对象,但这个对象不会赋值给一个标识符,而def则会把函数对象赋值给一个变量(函数名)
if或for或print等语句不能用于lambda中 lambda函数不能共享给别的程序调用,def定义的函数可以
语法 :
lambda [arg1[,arg2[,arg3...argn]]]:expression
>>> list1=[lambda a:a**3,lambda b:b**2]
>>> print list1
[<function <lambda> at 0x0000000003449A58>, <function <lambda> at 0x0000000003449AC8>]
>>> print list1[0]
<function <lambda> at 0x0000000003449A58>
>>> print list1[1]
<function <lambda> at 0x0000000003449AC8>
>>> g=list1[0]
>>> g(3)
27
>>> h=list1[1]
>>> h(2)
4
>>> h(4)
16
>>>
三、repr函数
用来取得对象的规范字符串表示。
反引号(也称转换符`)可以完成相同的功能。
注意:大多数时候有eval(repr(object))==object 可以通过定义类的__repr__方法来控制你的对象在被repr函数调用的时候返回的内容。
四、map函数
将每个列表元素或字符串都执行某个函数
map函数的操作方法:
它将每个字符串或者列表元素,应用某个函数方法,结果返回列表。
将函数func作用于这个seq的每个元素上,并得到一个新的seq.
>>> a=[1,2,3,4]
>>> lista=map(str,a)
>>> print lista ['1', '2', '3', '4']
>>>
>>> map(int,"12345")
[1, 2, 3, 4, 5]
>>>
>>> map(lambda x,y:x+y,[2,4,6],[3,2,1])
[5, 6, 7]
>>>
map函数无法处理seq长度不一致、对应位置操作数类型不一致的情况,会报类型错误。
>>> map(lambda x,y:(x**y,x+y),[2,4,6],[3,2,4,5]) #报错
Traceback (most recent call last): File "<stdin>", line 1, in <module> File "<stdin>", line 1, in <lambda>
TypeError: unsupported operand type(s) for ** or pow(): 'NoneType' and 'int'
>>> map(lambda x,y:(x**y,x+y),[2,4,6],[3,2,4])
[(8, 5), (16, 6), (1296, 10)]
>>>
五、filter函数:
filter()函数可以对序列做过滤处理,就是说可以使用一个自定义的函数,过滤一个序列 ,把序列的每一项传到自定义的过滤函数里处理,并将返回结果做过滤。最终一次性返回过滤后的 结果。
filter()函数有两个参数:
第一个是:自定义函数名,必须的
第二个是:需要过滤的序列,也是必须的
>>> def getsomenum(num):
... if num>5 and num<10:
... return num
...
>>> seq=[12,50,6,5,1,3,11,7,9,10]
>>> filter(getsomenum,seq)
[6, 7, 9]
>>>
六、reduce内建函数
reduce内建函数是一个二元操作函数,用来将一个集合(链表,元组等)中的所有数据进行下列 操作:
用传给reduce中的函数func()(必须是一个二元操作函数)先对集合的第1,2个数据进行操作 ,得到的结果再与第三个数据用func()函数运算,最后得到一个结果。(是一个累积的结果)
>>> reduce(lambda x,y:x+y,[1,2,3,4,5])
15
>>>
>>> reduce(lambda x,y:x+y,[1,2,3,4,5],0) #第一次把0给x,列表给y
15
>>>
>>> def fn(x,y):
... return x*10+y
...
>>> def char2num(s):
... return{"0":0,"1":1,"2":2,"3":3,"4":4,"5":5,"6":6,"7":7,"8":8,"9":9}[s]
...
>>> reduce(fn,map(char2num,"13579"))
13579
>>>
七、exec函数:
有时候可能会需要动态地创建python代码,然后将其他为语句或作为表达式去执行。
exec语句用来执行存储在字符串或文本中有效的python语句。
>>> exec("print 'hello python'")
hello python
>>>
>>> def printsrt():
...print "hello word"
... >>>
>>> exec("printsrt()")
hello word
>>>
八、eval函数
eval()语句用来计算存储在字符串中的有效Python表达式,并返回计算结果
>>> s="3*4+18"
>>> eval(s)
30
>>>
>>> def printStr():
... print "hello word"
... return 1
...
>>> print eval("printStr()")
hello word
1
>>>
>>> a="[[1,2],[3,4],[5,6]]"
>>> print eval(a)
[[1, 2], [3, 4], [5, 6]]
>>> b="{1:'xx',2:'yy'}"
>>> print eval(b)
{1: 'xx', 2: 'yy'}
>>> c="(1,2,3,4)"
>>> print eval(c)
(1, 2, 3, 4)
>>>
>>> list1=[1,2,3,4]
>>> type(`list1`)
<type 'str'>
>>> type(eval(`list1`))
<type 'list'>
>>> print eval(`list1`)
[1, 2, 3, 4]
>>>
九、exec与eval的区别:
exec()和eval()都可以动态的执行存储在字符串或文本中的有效python表达式;
区别:
exec()执行python语句没有返回值;
而eval()有返回值
十、range和xrange的区别:
rang会直接生成一个list对象;
xrange不会直接生成一个list,而是每次调用返回其中的一个值【xrange返回的是一个生成器】
>>> a=range(1,100)
>>> type(a)
<type 'list'>
>>> b=xrange(1,100)
>>> type(b)
<type 'xrange'>
>>>
函数(二):input、raw_input、lambda、repr、map、filter、reduce、eval、exec、range、xrange的更多相关文章
- python lambda表达式&map/filter/reduce
习条件运算时,对于简单的 if else 语句,可以使用三元运算来表示,即: 1 2 3 4 5 6 7 8 # 普通条件语句 if 1 == 1: name = 'wupeiqi' else ...
- python 内置函数 map filter reduce lambda
map(函数名,可遍历迭代的对象) # 列组元素全加 10 # map(需要做什么的函数,遍历迭代对象)函数 map()遍历序列得到一个列表,列表的序号和个数和原来一样 l = [2,3,4,5,6, ...
- python 函数对象(函数式编程 lambda、map、filter、reduce)、闭包(closure)
1.函数对象 作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 秉承着一切皆对象的理念,我们再次回头来看函数(function).函 ...
- lambda、map、reduce、filter函数讲解
# coding:utf-8 """ 几个特殊的函数: lambda lambda后面直接跟变量 变量后面是冒号 冒号后面是表达式,表达式计算结果就是本函数的返回值 作用 ...
- python常用函数进阶(2)之map,filter,reduce,zip
Basic Python : Map, Filter, Reduce, Zip 1-Map() 1.1 Syntax # fun : a function applying to the iterab ...
- 如何在python3.3用 map filter reduce
在3.3里,如果直接使用map(), filter(), reduce(), 会出现 >>> def f(x): return x % 2 != 0 and x % 3 != 0 ...
- 数组的高阶方法map filter reduce的使用
数组中常用的高阶方法: foreach map filter reduce some every 在这些方法中都是对数组中每一个元素进行遍历操作,只有foreach是没有 ...
- Swift map filter reduce 使用指南
转载:https://useyourloaf.com/blog/swift-guide-to-map-filter-reduce/ Using map, filter or reduce to ope ...
- python几个特别函数map filter reduce lambda
lambda函数也叫匿名函数,即,函数没有具体的名称.先来看一个最简单例子: def f(x): return x**2 print f(4) Python中使用lambda的话,写成这样 g = l ...
- lambda表达式&map&filter&yield
一.先来看下lambda表达式 1.lambda表达式其实很简单,他是简单的函数的变种,只有三部分组成,之前老师没有讲清楚,今天看书,终于明白了,写个博客记录下 lambda关键字+参数+返回值,参数 ...
随机推荐
- Leetcode刷题第003天
一.只出现一次的数字 class Solution { public: int singleNumber(vector<int>& nums) { ; for (auto num ...
- 现在k8s新版里,如何在每个node上运行一个带privileged的daemonset
以前,我们会在kubelet上加--allow-prividged启动参数来实现. 而现在,更推荐的是用pod secureity policy来实现.前面的那种方式以后会被废弃. https://k ...
- 一键安装基于dns的高可用k8s集群(3节点,etcd https)
在公司,使用dns切换,可能会比keepalived+haproxy,更精简的易维护. 毕竟,高可用只是偶尔切换,不是时时切换. 且dns解析在自己可控时,更不会影响k8s线上使用了. (部分代码,由 ...
- 一脸懵逼学习Storm的搭建--(一个开源的分布式实时计算系统)
Storm的官方网址:http://storm.apache.org/index.html :集群部署的基本流程(基本套路): 集群部署的流程:下载安装包.解压安装包.修改配置文件.分发安装包.启动集 ...
- 优化 Markdown 在 Notepad++ 中的使用体验
选择一个强大而好用的文本编辑器,是进行 Web 开发和编程必不可少的一部分,甚至对于通常的写作,一个舒服的文本编辑器也会让你写起文字来觉得优雅而潇洒.Sublime Text 是一款不错的编辑器,简洁 ...
- 事件监听addEventListener----attachEvent
第一:简单的通用方法(IE && FF) window.onload = function(){ var oDiv = document.getElementById("J_ ...
- Codeforces 781D Axel and Marston in Bitland 矩阵 bitset
原文链接https://www.cnblogs.com/zhouzhendong/p/CF781D.html 题目传送门 - CF781D 题意 有一个 n 个点的图,有 m 条有向边,边有两种类型: ...
- SPOJ LCS - Longest Common Substring 字符串 SAM
原文链接http://www.cnblogs.com/zhouzhendong/p/8982392.html 题目传送门 - SPOJ LCS 题意 求两个字符串的最长公共连续子串长度. 字符串长$\ ...
- 爬虫之xpath用法
导包用: from lxml import etree
- css 其他
去掉border和padding占用设置元素额外的宽高,使浏览器显示的元素宽高+border+padding的总和与设置的一致,它在浏览器的总宽=40px-border-padding (默认时: 设 ...