繁体   English   中英

pandas 使用 UTC 索引获取列值

[英]pandas get column values using UTC index

我有一个 pandas Dataframe 索引使用 UTC 时间和一个数据列(在示例中为“value_1”列)。

我的问题是:如何创建一个新列,其中每个值都是第一列的值但 20 秒后。 使用下面的示例,我将为第二列的第一个值获取“2011-01-01 00:00:20”时刻的值。

import pandas as pd  
import numpy as np

data_1 = pd.DataFrame(index=pd.date_range('1/1/2011', periods = 1000, freq ='S'))
data_1['value_1'] = 100 + np.random.randint(0,1000,size=(1000, 1))
data_1['value_2'] = ??¿¿

我不知道是否可以将索引更改为其他格式。

我已经看到 pandas 具有一些有用的功能来处理时间序列,但我还没有找到解决这个问题的功能。

先感谢您。

您可以将shift与您要使用的秒数一起使用(此处为 20):

data_1['value_2'] = data_1['value_1'].shift(-20)

或者可以使用 index + 20s 重新索引并使用to_numpy获取值:

data_1['value_2'] = data_1['value_1'].reindex(data_1['value_1'].index+pd.Timedelta(seconds=20)).to_numpy()

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM