def format_name(s):
return s.lower().capitalize()
print map(format_name, ['adam', 'LISA', 'barT'])
return s.lower().capitalize()
print map(format_name, ['adam', 'LISA', 'barT'])
2018-02-02
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 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()
就因不小心多打了个括号搞了我一下午才发现[捂脸](最后一行)
2018-02-02
def gcd(a, b):
if b == 0:
return a
return gcd(b, a % b)
欧几里得算法,辗转相除法。
即两个数的最大公约数 等于 其中较小的那个数 和 两数相除余数的最大公约数。
最大公约数(Greatest Common Divisor)缩写为GCD。
if b == 0:
return a
return gcd(b, a % b)
欧几里得算法,辗转相除法。
即两个数的最大公约数 等于 其中较小的那个数 和 两数相除余数的最大公约数。
最大公约数(Greatest Common Divisor)缩写为GCD。
2018-02-02
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, 个人感觉还是有一定难度的, 不过花时间弄懂了还是挺开心的
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, 个人感觉还是有一定难度的, 不过花时间弄懂了还是挺开心的
2018-02-02
sorted(L, cmp=lambda x,y:cmp(x[1],y[1])) # 利用cmp函数
sorted(L, key=lambda x:x[1]) # 利用key
sorted(L, key=lambda x:x[1]) # 利用key
2018-02-01
def calc(x,y):
return x*y
def calc_prod(lst):
def delay_calc():
return reduce(calc, lst)
return delay_calc
f = calc_prod([1, 2, 3, 4])
print f()
这一章我觉得学过C语言的人应该很好理解, f相当于是 接收一个函数返回了函数指针, 再通过f()来调用(C语言中用*f来调用)
return x*y
def calc_prod(lst):
def delay_calc():
return reduce(calc, lst)
return delay_calc
f = calc_prod([1, 2, 3, 4])
print f()
这一章我觉得学过C语言的人应该很好理解, f相当于是 接收一个函数返回了函数指针, 再通过f()来调用(C语言中用*f来调用)
2018-02-01
def cmp_ignore_case(s1, s2):
if s1.title() > s2.title():
return 1
elif s1.title() < s2.title():
return -1
else:
return 0
print sorted(['bob', 'about', 'Zoo', 'Credit'], cmp_ignore_case)
srot的内部实现我不清楚, 但肯定是调用了某种排序算法, 这里的比较, 如果返回-1, 则s1排在前面, 返回1, 则s1排在后面
if s1.title() > s2.title():
return 1
elif s1.title() < s2.title():
return -1
else:
return 0
print sorted(['bob', 'about', 'Zoo', 'Credit'], cmp_ignore_case)
srot的内部实现我不清楚, 但肯定是调用了某种排序算法, 这里的比较, 如果返回-1, 则s1排在前面, 返回1, 则s1排在后面
2018-02-01