首先是sorted函数,第一个参数为LIST 即 L1 第二个参数为定义的比较函数;
lambda p1, p2: cmp(p1.name, p2.name) 意思是,传入p1和p2,比较两者的name
这样一分解就容易理解了吧
lambda p1, p2: cmp(p1.name, p2.name) 意思是,传入p1和p2,比较两者的name
这样一分解就容易理解了吧
2016-04-10
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 p1.__count
except:
print 'attributeerror'
__count = 0
def __init__(self, name):
self.name=name
Person.__count+=1
print Person.__count
p1 = Person('Bob')
p2 = Person('Alice')
try:
print p1.__count
except:
print 'attributeerror'
2016-04-10
一定要用 super(Student, self).__init__(name, gender) 去初始化父类,否则,继承自 Person 的 Student 将没有 name 和 gender。
2016-04-10
def calc_prod(lst):
def prod(x,y):
return x*y
def result():
return reduce(prod,lst)
return result
f = calc_prod([1, 2, 3, 4])
print f()
def prod(x,y):
return x*y
def result():
return reduce(prod,lst)
return result
f = calc_prod([1, 2, 3, 4])
print f()
2016-04-10
最赞回答 / 魔luck
父类的初始化函数会先执行 ,最后才是 自己的初始化函数super(D, self).__init__(a)这句话,即先调用了 B C 的初始化,而B C 的初始化 又调用的 A 的 ,A的初始化有print 'init A...' 所以先输出 init A。 接下来 D 调用B C初始化那到底是先调用B 或者 C 呢?看这个class D(B, C),右边的参数先传入,即先调用了C。你可以试下B、C换下顺序 就明白了
2016-04-10
import math
def is_sqr(x):
return int(math.sqrt(x)) == math.sqrt(x)
print filter(is_sqr, range(1, 101))
def is_sqr(x):
return int(math.sqrt(x)) == math.sqrt(x)
print filter(is_sqr, range(1, 101))
2016-04-10
要定义关键字参数,使用 **kw;
除了可以直接使用self.name = 'xxx'设置一个属性外,还可以通过 setattr(self, 'name', 'xxx') 设置属性。
除了可以直接使用self.name = 'xxx'设置一个属性外,还可以通过 setattr(self, 'name', 'xxx') 设置属性。
2016-04-10
最新回答 / 魔luck
a,b,L=0,1,[]相当于a=0,b=1,L=[]。题目要生成斐波那契数列,所以设置了L接收数据,而L.append(a)意思是将a元素加入L数列。
2016-04-09
<code>
# 建议用这个:
def gcd(a,b):
while b:
a,b=b,a%b
return a
# 递归的效率低
# 还有
def __str__(self):
c = gcd(self.p, self.q)
return '%s/%s' % (self.p/c, self.q/c)
# 这样多次计算会导致p,q的值越来越大
# 这样:
def __init__(self, p, q):
self.p = p/gcd(p,q)
self.q = q/gcd(p,q)
# o(* ̄▽ ̄*)o
</code>
# 建议用这个:
def gcd(a,b):
while b:
a,b=b,a%b
return a
# 递归的效率低
# 还有
def __str__(self):
c = gcd(self.p, self.q)
return '%s/%s' % (self.p/c, self.q/c)
# 这样多次计算会导致p,q的值越来越大
# 这样:
def __init__(self, p, q):
self.p = p/gcd(p,q)
self.q = q/gcd(p,q)
# o(* ̄▽ ̄*)o
</code>
2016-04-09