为了账号安全,请及时绑定邮箱和手机立即绑定

python进阶

廖雪峰 移动开发工程师
难度中级
时长 3小时33分
学习人数
综合评分9.20
575人评价 查看评价
9.6 内容实用
9.0 简洁易懂
9.0 逻辑清晰
def prod(x, y):
return x*y

print reduce(prod, [2, 4, 5, 7, 12])
s.append(f),只是将每一个f()的引用保存进了list,并没有进行对于i的计算,所以导致最后在运行了f(1)之后,i已经变为了3,所以会一样结果都为9.只要将这里改为fs.append(f())即可,这样就在这一步的时候已经进行了i*i的运算,将结果保存了,通过这一题可以注意到在python这门语言之中,f与f()的大区别。
def calc_prod(lst):
def f(x,y):
return x*y
def lazy_prod():
return reduce(f,lst)
return lazy_prod

f = calc_prod([1, 2, 3, 4])
print f()
class Person(object):

def __init__(self, name, gender, **kw):
self.name=name
self.gender=gender
for k,v in kw.iteritems():
setattr(self,k,v)

p = Person('Bob', 'Male', age=18, course='Python')
print p.age
print p.course
import json

class Students(object):
def read(self):
return r'["Tim","Bob","Alice"]'

s = Students()

print json.load(s)
def calc_prod(lst):
def cheng(x,y):
return x*y
def a(list):
return map(cheng,lst)
return a

f = calc_prod([1, 2, 3, 4])
print f()
class Person(object):

__count = 0
@classmethod
def how_many(cls):
return cls.__count
def __init__(self,name):
self.name=name
Person.__count=Person.__count+1
print Person.how_many()

p1 = Person('Bob')

print Person.how_many()
直接把 lambda 函数赋值给 self.get_grade 和绑定方法有所不同,函数调用不需要传入 self,但是方法调用需要传入 self。
class Person(object):
count=0
def __init__(self,name):
self.name=name
Person.count=Person.count+1
p1 = Person('Bob')
print Person.count

p2 = Person('Alice')
print Person.count

p3 = Person('Tim')
print Person.count
class Person(object):
def __init__(self, name, score):
self.name=name
self.__score=score

p = Person('Bob', 59)

print p.name
print p.__score
def performance(unit):
def perf_decorator(f):
@functools.wraps(f)
def wrapper(*args, **kw):
print 'call',f._name_+'() in',time().unit
return wrapper
return perf_decorator
这是改正之后的,上一个答案里面 in 前面要加一个空格才能通过。至于为什么time().unit能通过我也不知道,自己乱试的,也许内置有这个时间格式函数 def performance(unit): def performance_decorator(f): def fn(x): print 'call'+f._name_+'() in',time().unit return f(x) return fn return performance_decorator

最新回答 / 秋而
这个unit的意思是出入的注解的时间单位,类如:@performance('ms') 表示单位是毫秒,是一种友好的提示;所以不是time的内置函数
def performance(unit):
def performance_decorator(f):
def fn(x):
print 'call'+f._name_+'()in',time().unit
return f(x)
return fn
return performance_decorator
课程须知
本课程是Python入门的后续课程 1、掌握Python编程的基础知识 2、掌握Python函数的编写 3、对面向对象编程有所了解更佳
老师告诉你能学到什么?
1、什么是函数式编程 2、Python的函数式编程特点 3、Python的模块 4、Python面向对象编程 5、Python强大的定制类

微信扫码,参与3人拼团

意见反馈 帮助中心 APP下载
官方微信
友情提示:

您好,此课程属于迁移课程,您已购买该课程,无需重复购买,感谢您对慕课网的支持!

本次提问将花费2个积分

你的积分不足,无法发表

为什么扣积分?

本次提问将花费2个积分

继续发表请点击 "确定"

为什么扣积分?

举报

0/150
提交
取消