使用 Pandas DataFrame 处理时间


在本文中,我们将学习如何使用内置的 pandas 库生成和处理不同的时间戳。我们还使用 numpy 模块来生成和修改时间戳生成所需的数据库。

首选 IDE:Jupyter notebook

在开始本教程之前,我们必须安装 pandas 和 numpy 库。对于此 jupyter notebook 是测试和运行代码的最佳场所。要安装 pandas,我们必须运行以下命令。

>>> pip install pandas

如果我们运行此命令,所有依赖项将自动安装。完成后,我们必须重新启动内核以查看更改。

安装完所有依赖项后,我们可以将 pandas 导入为“p”。

在这里,我们调用数据帧构造函数并使用日期参数初始化一个周期为 4、频率为 2 小时的数据库。通过指定键“time”,我们正在显示数据库。

>>> pip install pandas
>>> import pandas as p
>>> data_struct = p.DataFrame()
>>> data_struct['time'] = p.date_range('14/7/2019', periods = 4, freq='3H')
>>> print(data_struct['time'])
0 2019-07-14 00:00:00
1 2019-07-14 03:00:00
2 2019-07-14 06:00:00
3 2019-07-14 09:00:00
Name: time, dtype: datetime64[ns]

通过使用 <data_struct>.dt.<特征名称>提取特征。通过使用 head() 方法,我们显示数据库中的所有行。

>>> data_struct['year'] = data_struct['time'].dt.year
>>> data_struct.head(4)
   time
0 2019-07-14 00:00:00 2019
1 2019-07-14 03:00:00 2019
2 2019-07-14 06:00:00 2019
3 2019-07-14 09:00:00 2019

在这里,我们实现了 numpy 模块中存在的 .array() 函数来创建时间字符串。这些字符串通过使用 pandas 库中的 .to_datetime() 方法转换为 DateTime。

>>> import numpy as n
>>> dt_timestring = n.array(['14-07-2019 07:26 AM', '13-07-2019 11:01 PM'])
>>> timestamps = [p.to_datetime(date, format ="%d-%m-%Y %I:%M %p", errors ="coerce") for date in dt_timestring]
>>> print(timestamps)
[Timestamp('2019-07-14 07:26:00'), Timestamp('2019-07-13 23:01:00')]

在这里,我们使用日期对数据库进行索引,这意味着“date”字段将首先通过使用 .set_index() 方法显示。

>>> data_struct1 = p.DataFrame()
>>> data_struct1['date'] = p.date_range('18/07/2019', periods = 5, freq ='2H')
>>> data_struct1= data_struct1.set_index(data_struct1['date'])
>>> print(data_struct1.head(5))
   date
date
2019-07-18 00:00:00 2019-07-18 00:00:00
2019-07-18 02:00:00 2019-07-18 02:00:00
2019-07-18 04:00:00 2019-07-18 04:00:00
2019-07-18 06:00:00 2019-07-18 06:00:00
2019-07-18 08:00:00 2019-07-18 08:00:00

如果我们只想从数据库中显示特定的数据集,那么我们可以实现如下所述的命令 -

>>> data_struct2 = p.DataFrame()
>>> data_struct2['date'] = p.date_range('17/07/2019', periods =3, freq ='4H')
>>> print(data_struct2.head(5))
   date
0 2019-07-17 00:00:00
1 2019-07-17 04:00:00
2 2019-07-17 08:00:00
>>> inp = data_struct2[(data_struct2['date'] > '2019-07-17 04:00:00')]
>>> print(inp)
   date
2 2019-07-17 08:00:00

结论

在本文中,我们学习了如何以多种方式打包和解包元组。

更新于: 2019年8月29日

147 次浏览

开启你的 职业生涯

通过完成课程获得认证

立即开始
广告