“ Python没有这种功能似乎很愚蠢,因为如果不这样做,那么如果它是要传递的列表的一部分,那么您将无法重新定义通过for循环传递的任何变量。” -这就是大多数编程语言的工作方式。允许此功能将是不好的,因为它将创建称为副作用的东西,这会使代码变得晦涩难懂。
另外,这是一个常见的编程陷阱,因为您应该 :请参阅http://nedbatchelder.com/blog/201112/keep_data_out_of_your_variable_names.html(尤其是类似问题的列表;即使您不处理变量也是如此)名称,您至少要处理变量名称空间)。补救措施是在“更高一级”上工作:在这种情况下为列表或集合。这就是为什么您最初的问题不合理的原因。(某些版本的python将使您可以破解@H_301_5@locals()字典,但这是不受支持的和未记录的行为,而且样式很差。)
但是,您可以强制python使用如下副作用:
@H_301_5@scores = [99.1, 78.3, etc.] for i,score in enumerate(scores): scores[i] = int(score)
以上将在@H_301_5@scores数组中舍入分数。但是, (除非您正在处理数亿个元素)是重新创建@H_301_5@scores数组,如下所示:
@H_301_5@scores = [...] roundedscores = [int(score) for score in scores]
如果您有很多事情想得分:
@H_301_5@scores = [..., ..., ...] def processscores(scores): '''Grades on a curve, where top score = 100%''' theTopscore = max(scores) def processscore(score, topscore): return 100-topscore+score newscores = [processscore(s,theTopscore) for s in scores] return newscores
旁注:如果要进行浮点计算,则应@H_301_5@from __future__ import division使用python3或将其强制转换为@H_301_5@float(...)显式。
如果您确实要修改传入的内容,则可以传入可变对象。您传递的数字是不可变对象的实例,但是例如,如果您有:
@H_301_5@class score(object): def __init__(self, points): self.points = points def __repr__(self): return 'score({})'.format(self.points) scores = [score(i) for i in [99.1, 78.3, ...]] for s in scores: s.points += 5 # adds 5 points to each score
这仍然是一种无功能的处理方式,因此容易产生副作用所引起的所有问题。