python一则关于倒序求差值的具体问题。

如图所示,已知X列数据,现需生成Y列数据,要求Y列数据为X列每一行数值减去上一行数值。

如:Y1=X2-X1,Y2=X3-X2,Y3=X4-X3....

 

>>> import numpy as np
>>> x = np.array([2,-1.8,-1.1,1.5,2.3,2.1,1.8])
>>> y = np.diff(x)
>>> y
array([-3.8,  0.7,  2.6,  0.8, -0.2, -0.3])

 

data = [
    [1,7,0],
    [2,24,0],
    [3,57,0],
    [4,78,0],
]
for i in range(len(data)-1):
    data[i][2] = data[i+1][1] - data[i][1]
print(*data,sep='\n')

 

试试这个:

import pandas as pd
import numpy as np

data = pd.DataFrame({'X':[2,-1.8,-1.1,1.5,2.3,2.1,1.8]})
data['Y'] = data['X'].shift(-1) -data['X']
print(data)
     X    Y
0  2.0 -3.8
1 -1.8  0.7
2 -1.1  2.6
3  1.5  0.8
4  2.3 -0.2
5  2.1 -0.3
6  1.8  NaN

 

您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

速戳参与调研>>>https://t.csdnimg.cn/Kf0y