def is_sqr(x):
math.modf( math.sqrt(x) )[0] != 0.0
print filter(is_sqr, range(1, 101))
math.modf( math.sqrt(x) )[0] != 0.0
print filter(is_sqr, range(1, 101))
2015-12-06
闭包的定义是:内层函数引用了外层函数的变量然后返回内层函数.我的理解是在原程序中
def f():
return i*i
fs.append
这段内层函数的变量i并没有从外层函数导入.改为:
def f(j=i):
return j*j
fs.append(f)
def f():
return i*i
fs.append
这段内层函数的变量i并没有从外层函数导入.改为:
def f(j=i):
return j*j
fs.append(f)
2015-12-06
sorted()也是一个高阶函数,它可以接收一个比较函数来实现自定义排序,比较函数的定义是,传入两个待比较的元素 x, y,如果 x 应该排在 y 的前面,返回 -1,如果 x 应该排在 y 的后面,返回 1。如果 x 和 y 相等,返回 0
2015-12-01
class Person(object):
pass
p1 = Person()
p1.name = 'Bart'
p2 = Person()
p2.name = 'Adam'
p3 = Person()
p3.name = 'Lisa'
L1 = [p1, p2, p3]
L2 = sorted(L1,key=lambda x:x.name)
print L2[0].name
print L2[1].name
print L2[2].name
pass
p1 = Person()
p1.name = 'Bart'
p2 = Person()
p2.name = 'Adam'
p3 = Person()
p3.name = 'Lisa'
L1 = [p1, p2, p3]
L2 = sorted(L1,key=lambda x:x.name)
print L2[0].name
print L2[1].name
print L2[2].name
2015-11-26
class Person(object):
pass
p1 = Person()
p1.name = 'Bart'
p2 = Person()
p2.name = 'Adam'
p3 = Person()
p3.name = 'Lisa'
L1 = [p1, p2, p3]
L2 = sorted(L1,lambda x:x.name)
print L2[0].name
print L2[1].name
print L2[2].name
pass
p1 = Person()
p1.name = 'Bart'
p2 = Person()
p2.name = 'Adam'
p3 = Person()
p3.name = 'Lisa'
L1 = [p1, p2, p3]
L2 = sorted(L1,lambda x:x.name)
print L2[0].name
print L2[1].name
print L2[2].name
2015-11-26