最赞回答 / Cindy_79
f1, f2, f3 = count() 这句调用count函数,返回的是函数列表,[i*i,i*i,i*i]=count()而不是函数值。fs.append(f)这句将函数f加入到fs中去,等于fs中加入的是函数,而非函数值,fs=[i*i],所以当循环结束后,i已经是3了,所以最终的f1 f2 f3 再去计算i*i的时候就都是9了
2015-07-29
最赞回答 / 放学路上的小学生
不是的哦。self.k意思是给实例增加了个k属性,这里的k是固定不变的,和name,score什么的没区别。而setattr(self, k, v)里的k和v是变量,是动态变化的。见下图,直接打印 a.k属性,这个属性名称就是k。<...图片...>
2015-07-24
最新回答 / 5941
首先,我想说,请你把完整的代码放上来,不要放这种存在错误的,不能执行的代码。第二,None 应该是你的print test()打印出来的,因为你的test()函数没有定义返回值,所以返还了个None,也就打印了None
2015-07-21
最赞回答 / 5941
and 就是与,s and len(s.strip()) > 0的意思要根据and的短路作用来看。如果s不存在,返回s; 如果s存在,返回len(s.strip()) > 0即如果s不存在,返回None,如果s存在,则判断s去掉空格之后的长度是否大于0,如果是,返回True,如果否则返回False。你注意看题中的list:['test', None, '', 'str', ' ', 'END'],其中有个None,在有's and' 的时候,是不会进行后面的len(s.strip())&g...
2015-07-20
最赞回答 / qq_忆_4
return f(x)是返回原来函数的返回值...fn是一个新函数...return fn是返回新函数..新函数 新操作 调用旧函数是一个这样的形式吧..也就是说这样的话就扩充了旧函数的功能了..执行过程应该是这样...先log(f)得到新函数的地址..之后调用新函数就完成了对旧函数的扩充...(这个地址的说法来源于C语言,理解的不对的地方还请谅解..菜鸟一只)
2015-07-17
最赞回答 / 5941
在本题你这么看好像是没什么差别,但是你放到上一题就可以看出差别了。没有return r,你调用factorial()的结果是None,因为没有返回值回来。有了return r,才能输出factorial计算的阶乘答案。本题没差别的原因是本题中并没有调用factorial函数,而是只取了它的__name__这个属性。
2015-07-13
最新回答 / 码农的自我修养
(f.__name__, t, unit)是个元组,%s可以理解成对应参数'call %s() in %f %s' % (f.__name__, t, unit) 也可以这样写:'call %s() in %s [%s]' % (f.__name__, time.time()-start, unit)#f.__name__是取函数名,start=time.time(),开始运算时间,unit是传入的单位。入门课程里面有个类似的,复杂表达式 那里
2015-07-12