eval和列表解析的一处陷阱】的更多相关文章

>>> def f(): a=1 return [i+a for i in range(3)] >>> f() [1, 2, 3] >>> def f(): a=1 return [i+eval('a') for i in range(3)] >>> f() Traceback (most recent call last): File "<pyshell#13>", line 1, in <mo…
一.装饰器 一.装饰器的知识储备 1.可变长参数  :*args和**kwargs def index(name,age): print(name,age) def wrapper(*args,**kwargs): #即args=(1,2,3,4,5),kwargs={'x':1,'y':3} index(*args,**kwargs) #index(1,2,3,4,5,y=2,x=5) 2.函数对象:被当做数据传递 1.函数可以当做参数传给另外一个函数 2.一个函数的返回值,也可以是一个函数(…
1.文件读取方类型 r,r+,w,x,a, r,读文件 w,写文件,文件内容全部删除,并将新内容从第一行开始赋值 x,写文件,只有文件不存在,可写,文件存在,报错 a,在文件莫问追加信息 r+,w+,x+,a+ 文件均为可读可写 rb,wb,xb,ab rb,b的方式不能指定编码,读出原生二进制码,要显示原生字符需要解码操作 f = open('test11.py','rb') data = f.read() print(data) window平台,二进制可显示回车符‘\r\n’ 2.文件处理…
1.迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外,迭代器的一大优点是不要求事先准备好整个迭代过程中所有的元素.迭代器仅仅在迭代到某个元素时才计算该元素,而在这之前或之后,元素可以不存在或者被销毁.这个特点使得它特别适合用于遍历一些巨大的或是无限的集合,比如几个G的文件 特点: 可迭代对象遵循可迭代器协议 访问者不需要关心迭代器内部的结构,仅需通过next()方法…
一.装饰器 一.装饰器的知识储备 不想修改函数的调用方式,但是还想在原来的函数前后添加功能 1.可变长参数  :*args和**kwargs def index(name,age): print(name,age) def wrapper(*args,**kwargs): #即args=(1,2,3,4,5),kwargs={'x':1,'y':3} index(*args,**kwargs) #index(1,2,3,4,5,y=2,x=5) 2.函数对象:被当做数据传递 1.函数可以当做参数…
列表解析是列表类型的方法,这种方法结合了列表的方括弧.for循环.if语句. 用for把处理后的值放入列表: squared = [ x**2 for x in range(4) ] for i in squared: print i 0 1 4 9 [ i*2 for i in [8,-2,5] ] [16,-4,10] 2. 挑选符合要求的值放入列表 sqdEvens = [x**2 for x in range(8) if not x % 2 ] for i in sqdEvens: pr…
filter用法 filter(func,seq) 将seq的元素逐一代入func,通过func的返回值来判断是保留还是过滤 >>> def foo(x): return x>3 >>> filter(foo,range(6)) [4, 5] >>> filter(lambda x:x>3,range(6))[4, 5] #注意只需要写函数名,不带参数 map用法map(func/lambda,seq) 通过函数对队列中的每个元素进行操作,…
一.自定义函数 定义函数时,函数体不执行:只有在调用函数时,函数体才执行.函数的结构: 1. def 2. 函数名 3. 函数体 def func_name(): 函数体 4. 返回值 如果没有声明返回值,返回值默认为None def func_name(): pass return True def func_name(): myString = 'this is to test how to return' return mySting 5. 参数 形式参数 定义函数时出现的参数,称之为形式…
列表解析: 根据已有列表,高效生成列表的方式,它的执行效率要快很多,比for循环的速度要快很多 示例如下: 生成器表达式 生成器表达式并不真正创建数字列表,而是返回一个生成器对象,此对象在每次计算出一个条目后,把这个条目"产生"出来 生成器表达式使用了"惰性计算"或称作"延迟求值"的机制 序列过长,并且每次只需要获取一个元素时,应当考虑使用生成器表达式而不是列表解析 列表解析:生成列表很方便,也很强大,但很占用资源 文件对象 Python内置函数…
一.列表解析 列表解析来自函数式编程语言(haskell),语法如下: [expr for iter_var in iterable] [expr for iter_var in iterable if cond_expr] 第一种语法:首先迭代iterable里所有内容,每一次迭代,都把iterable里相应内容放到iter_var中,再在表达式中应用该iter_var的内容,最后用表达式的计算值生成一个列表. 第二种语法:加入了判断语句,只有满足条件的内容才把iterable里相应内容放到i…