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

python进阶

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

def f(L):
return L ** 0.5

print(add(25, 9, f))
print filter(lambda s:len(s.strip())>0 if s else False, ['test', None, '', 'str', ' ', 'END'])
emm 用if写的虽然结果对但是不能通过
import time

def performance(f):
def fn(x):
print 'call', f.__name__, '()in', time.time()
return f(x)
return fn

@performance
def factorial(n):
return reduce(lambda x,y: x*y, range(1, n+1))

print factorial(10)
评论里有写代码好可怕。。。
1/2+1/4=3/4
1/2-1/4=1/4
1/2*1/4=1/8
1/2÷1/4=2/1
from math import *

def add(x, y, f):
return f(x) + f(y)

print add(25, 9, sqrt)
表示同样是小白,我一下午把装饰器艹完,同样是小白有人需要一周,修行看个人,百度都被我艹烂了[滑稽]
def format_name(s):
return s.lower().capitalize()
print map(format_name, ['adam', 'LISA', 'barT'])
import time
def performance(f):
def fa(*args,**kw):
Timetuple=time.localtime()
fmt='%Y-%m-%d %a %H:%M:%S'
t=time.strftime(fmt,Timetuple)
print 'call %s() in %s' %(f.__name__,t)
return f(*args,**kw)
return fa # return fa()
就因不小心多打了个括号搞了我一下午才发现[捂脸](最后一行)
太棒了,这一节看高潮了
def gcd(a, b):
if b == 0:
return a
return gcd(b, a % b)
欧几里得算法,辗转相除法。
即两个数的最大公约数 等于 其中较小的那个数 和 两数相除余数的最大公约数。
最大公约数(Greatest Common Divisor)缩写为GCD。
def fn(*args, **kw):
t1 = time.time() #运行前的时间
r = f(*args, **kw) #调用 factorial()函数, 并将结果赋值给r
t2 = time.time() #运行后的时间
print 'call %s() in %f' % (f.__name__, (t2-t1)) # 格式化输出 %s是字符串, %f是浮点型
return r #这里返回是r, 而不是r(), 因为调用过factorial()
return fn
我也是第一次学Python, 个人感觉还是有一定难度的, 不过花时间弄懂了还是挺开心的
print 'call %s()' % f.__name__
print 'call %s()' f.__name__
看了半天才知道 这里的log是记录, 一开始看还以为是数学里面的log
cmp是由低到高,加上-就变由高到低了
课程须知
本课程是Python入门的后续课程 1、掌握Python编程的基础知识 2、掌握Python函数的编写 3、对面向对象编程有所了解更佳
老师告诉你能学到什么?
1、什么是函数式编程 2、Python的函数式编程特点 3、Python的模块 4、Python面向对象编程 5、Python强大的定制类

微信扫码,参与3人拼团

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

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

本次提问将花费2个积分

你的积分不足,无法发表

为什么扣积分?

本次提问将花费2个积分

继续发表请点击 "确定"

为什么扣积分?

举报

0/150
提交
取消