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

python进阶

廖雪峰 移动开发工程师
难度中级
时长 3小时33分
学习人数
综合评分9.20
575人评价 查看评价
9.6 内容实用
9.0 简洁易懂
9.0 逻辑清晰
实例化一个对象的时候, 实例化对象引用了类的属性(能够访问).
修改类的属性, 实例化对象访问/引用的属性值相应改变.

但是如果修改实例的属性值, 将会引用到一个新的内存地址, 而这个实例的被修改属性将不再引用类的属性值.
def count():
fs = []
for i in range(1, 4):
def f(j):
return j*j;
r = f(i);
fs.append(r)
return fs
f1, f2, f3 = count()
print f1,f2,f3
def is_sqr(x):
return x**0.5 == int(x**0.5)
print filter(is_sqr, range(1, 101))
学习得越来越吃力了,有同感的抱紧我。。。
class Person(object):

__count = 0

@classmethod
def how_many(cls):

return cls.__count;
def __init__(self,name):
self.name = name
Person.__count +=1


print Person.how_many()

p1 = Person('Bob')

print Person.how_many()
装饰器不难, 关键是要理解为什么要包裹这么多层. 本质是每一层函数的目的都是为了接收和处理参数.

所以装饰器使用起来也是需要多层传参, 而不是一次传入多个参数.
很难吗, 前面那么多小节在铺垫都不看的吗???
为啥这个视频我就放不出来。。。。
妈了个巴子的 ,直接跳过
return cmp(s1[0].lower(),s2[0].lower())
感觉高阶函数这个高大上名字还是比较装逼了...
def is_sqr(x):
return math.sqrt(x) == round(math.sqrt(x))
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):
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
try:
print p.__score
except AttributeError:
print 'attributeerror'
课程须知
本课程是Python入门的后续课程 1、掌握Python编程的基础知识 2、掌握Python函数的编写 3、对面向对象编程有所了解更佳
老师告诉你能学到什么?
1、什么是函数式编程 2、Python的函数式编程特点 3、Python的模块 4、Python面向对象编程 5、Python强大的定制类

微信扫码,参与3人拼团

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

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

本次提问将花费2个积分

你的积分不足,无法发表

为什么扣积分?

本次提问将花费2个积分

继续发表请点击 "确定"

为什么扣积分?

举报

0/150
提交
取消