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

python进阶

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

最赞回答 / wuchongxiang0
在python中,如果已知一个属性名称,要获取或者设置对象的属性,就需要用 getattr() 和 setattr( )函数

已采纳回答 / yskcg
f 这个 对象或者函数,没有_name_ 属性,是__name__属性import timefrom functools import reducedef performance(f):    def fn(*args, **kw):        t1=time.time()        r=f(*args, **kw)        t2=time.time()        print ('call %s() in %fs' % (f.__name__ ,(t2- t1)))        ret...
class Fib(object):
def __call__(self, num):
L = [0, 1]
for i in range(num - 2):
L.append(L[i] + L[i +1])
return L

f = Fib()
print f(10)
import math

def is_sqr(x):
return x and math.sqrt(x)%1==0

print filter(is_sqr, range(1,101))
继承关系的__slots__的继承关系是:
子类的__slots__ + 父类的__slots__类。
def __str__(self):
def divisor(a,b):
tmp=max(a,b)%min(a,b)
if tmp==0:
return min(a,b)
else:
return divisor(min(a,b),tmp)
divnum = divisor(self.p, self.q)
return '%s/%s' % (self.p / divnum, self.q / divnum)
class Fib(object):
def __init__(self, num):
fibl=[0,1]
for item in range(0, num -2):
fibl.append(fibl[item] + fibl[item + 1])
self.fibList = fibl
def __str__(self):
return str(self.fibList)
def __len__(self):
return len(self.fibList)
def format_name(s):

return s.title()

print map(format_name, ['adam', 'LISA', 'barT'])
class Person(object):
__count = 0
def __init__(self,name):
self.name = name
Person.__count += 1

@staticmethod
def how_many():
return Person.__count

@classmethod
def how_many2(cls):
return cls.__count
# -*- coding: utf-8 -*-
class Person(object):
def get_grade(self):
if self.__score > 85:
return "A-优秀"
elif self.__score > 60:
return "B-及格"
else:
return "C-不及格"
class Person(object):
__count = 0
def __init__(self, name):
self.name = name
Person.__count +=1
print Person.__count

p1 = Person('Bob')
p2 = Person('Alice')

try:
print Person.__count
except AttributeError:
print 'AttributeError'
class Person(object):
count = 0
def __init__(self,name):
Person.count +=1
self.name = name
try:
print p.__score
except AttributeError:
print ('attributeError')
考察try...except的错误信息处理

最新回答 / weibo_恩赐野兔_0
目的是:将f函数的信息通过functools.wraps(f)赋值给wrapper,保证了在@performance('ms')后,赋值给factorial的函数信息没有被修改。位置应当是一种固定格式。
import time
def performance(f):
def fn(x):
t1 = time.time()
f(x)
t2 = time.time()
print "call factorial() in time = %f (ms)" % ( t2 - t1)
return fn
@performance
def factorial(n):
return reduce(lambda x,y: x*y, range(1, n+1))
print factorial(10)
根本不用花费时间。
def calc_prod(lst):
def prodxy():
return reduce(lambda x, y:x*y, lst)

return prodxy

f = calc_prod([1, 2, 3, 4])
print f()
课程须知
本课程是Python入门的后续课程 1、掌握Python编程的基础知识 2、掌握Python函数的编写 3、对面向对象编程有所了解更佳
老师告诉你能学到什么?
1、什么是函数式编程 2、Python的函数式编程特点 3、Python的模块 4、Python面向对象编程 5、Python强大的定制类

微信扫码,参与3人拼团

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

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

本次提问将花费2个积分

你的积分不足,无法发表

为什么扣积分?

本次提问将花费2个积分

继续发表请点击 "确定"

为什么扣积分?

举报

0/150
提交
取消