gpt4 book ai didi

python - 如何将 Pandas 时区感知时间戳转换为 UNIX 纪元?

转载 作者:行者123 更新时间:2023-11-28 18:43:50 29 4
gpt4 key购买 nike

我需要将时区感知 date_range (TimeStamps) 转换为 UNIX 纪元值,以便在外部 Javascript 库中使用。

我的做法是:

# Create localized test data for one day
rng = pd.date_range('1.1.2014', freq='H', periods=24, tz="Europe/Berlin")
val = np.random.randn(24)
df = pd.DataFrame(data=val, index=rng, columns=['values'])

# Reset index as df column
df = df.reset_index()

# Convert the index column to the desired UNIX epoch format
df['index'] = df['index'].apply(lambda x: x.value // 10**6 )

df['index'] 包含预期的 UNIX 纪元值,但它们存储在 UTC(!) 中。

我想这是因为 pandas 在后台将时间戳存储在 numpy UTC datetime64 值中。

是否有一种聪明的方法可以在请求的时区中获得“正确的”纪元值?

This proposal doesn't work with DST

最佳答案

In [17]: df
Out[17]:
values
2014-01-01 00:00:00+01:00 1.027799
2014-01-01 01:00:00+01:00 1.579586
2014-01-01 02:00:00+01:00 0.202947
2014-01-01 03:00:00+01:00 -0.214921
2014-01-01 04:00:00+01:00 0.021499
2014-01-01 05:00:00+01:00 -1.368302
2014-01-01 06:00:00+01:00 -0.261738

2014-01-01 22:00:00+01:00 0.808506
2014-01-01 23:00:00+01:00 0.459895

[24 rows x 1 columns]

使用索引方法asi8转换为int64(自epoch以来已经在ns中)这些是 UTC 时间!

In [18]: df.index.asi8//10**6
Out[18]:
array([1388530800000, 1388534400000, 1388538000000, 1388541600000,
1388545200000, 1388548800000, 1388552400000, 1388556000000,
1388559600000, 1388563200000, 1388566800000, 1388570400000,
1388574000000, 1388577600000, 1388581200000, 1388584800000,
1388588400000, 1388592000000, 1388595600000, 1388599200000,
1388602800000, 1388606400000, 1388610000000, 1388613600000])

这些是自纪元以来的本地时区。请注意,这通常不是公共(public)方法,我总是会交换 UTC 数据(如果需要,还可以交换时区)。

In [7]: df.index._local_timestamps()//10**6
Out[7]:
array([1388534400000, 1388538000000, 1388541600000, 1388545200000,
1388548800000, 1388552400000, 1388556000000, 1388559600000,
1388563200000, 1388566800000, 1388570400000, 1388574000000,
1388577600000, 1388581200000, 1388584800000, 1388588400000,
1388592000000, 1388595600000, 1388599200000, 1388602800000,
1388606400000, 1388610000000, 1388613600000, 1388617200000])

关于python - 如何将 Pandas 时区感知时间戳转换为 UNIX 纪元?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22916018/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com