如何计算lis中的数字

2024-03-29 15:56:29 发布

您现在位置:Python中文网/ 问答频道 /正文

这是我的密码。你知道吗

A = [86.14803712, 85.25496701, 86.50334271, 86.0266668,  86.61455594, 86.90445213, 86.65519315, 87.10116762, 87.08173861]
B = []
i = 0
for i in range(len(A)):
    c = A[i]-A[i-1]
    B.append(c)
    print(c)

我想得到这个列表中两个连续数字之间的差异,例如,(85.25496701-86.14803712)。所以在结果中,我应该有8个数字作为结果。你知道吗

但我得到的结果是:

-0.9337014900000042
-0.8930701099999965 
1.2483756999999969
-0.4766759099999973
0.5878891400000015
0.2898961899999932
-0.24925897999999336
0.4459744699999959
-0.019429009999996083

我不需要-0.9337014900000042,因为它来自于列表中的第一个数字减去最后一个数字。我该怎么做才能修好它?谢谢


Tags: in密码列表forlenrange数字差异
3条回答

你可以这样做:

B = [x-y for x, y in zip(A[1:], A)]
print(B)  # -> [-0.8930701099999965, 1.2483756999999969, -0.4766759099999973, 0.5878891400000015, 0.2898961899999932, -0.24925897999999336, 0.4459744699999959, -0.019429009999996083]

在基本Python中可以做到这一点,但您可能会喜欢Pandas的语义清晰性:

import pandas as pd
pd.Series(A).diff().values[1:]

array([-0.89307011,  1.2483757 , -0.47667591,  0.58788914,  0.28989619,
       -0.24925898,  0.44597447, -0.01942901])

这就是python的优点和缺点:当列表不为空时,索引-1总是有效的,这会导致程序不会崩溃,但不会做您想做的事情。你知道吗

对于这些操作,最好使用zip将列表与不带第一个数字的自身切片版本交错:

A = [86.14803712, 85.25496701, 86.50334271, 86.0266668,  86.61455594, 86.90445213, 86.65519315, 87.10116762, 87.08173861]

diffs = [ac-ap for ac,ap in zip(A[1:],A)]

或使用itertools.islice以避免创建新列表进行迭代:

import itertools
diffs = [ac-ap for ac,ap in zip(itertools.islice(A,1,None),A)]

结果(8个值):

[-0.8930701099999965, 1.2483756999999969, -0.4766759099999973, 0.5878891400000015, 0.2898961899999932, -0.24925897999999336, 0.4459744699999959, -0.019429009999996083]

相关问题 更多 >