我有一个清单
l = [object0, object1, object2, object3, object4....object499]
最大长度不超过500
所有对象都具有属性x,y,z,a
如果在object.x中重复为:,我必须修改object.y:
if object9.x == object10.x:
object9.y = object9.z * object9.a/1000
object10.y = object10.y - object9.z * object9.a/1000
保证重复项将出现在连续的对象中。
例如,可能有两个以上重复项
object12.x == object13.x == object14.x
所以修改将基于修改后的第二个副本的值以与第三个副本相同的方式进行。
我写了一个循环来做,但是在想是否有任何Pythonic /更快的方法来做。我正在使用python3.7
编辑:
tag = None
for i, o in enumerate(l):
if tag is None:
x_a = o.x
elif x_a == o.x #duplicate found
temp = o.y
c_over = 0
c_value = o[i-1].z * o[i-1].a/1000
if c_value < o[i-1].y:
o[i-1].y = c_value
c_over = temp - c_value #carry over value
o[i] = c_over # either zero of carry over value
x_a = o.x