pandas :将时间戳转换为 datetime.date

pandas :将时间戳转换为 datetime.date
首先,我们需要导入`pandas`库。然后,我们可以使用`pd.to_datetime()`函数将时间戳转换为日期对象。最后,我们可以使用`.dt.date`属性来获取日期部分。

以下是详细的步骤:

1. 导入`pandas`库:
```python
import pandas as pd
```

2. 创建一个包含时间戳的DataFrame:
```python
data = {'timestamp': [1597962000, 1597958000, 1597954000]}
df = pd.DataFrame(data)
```

3. 将时间戳转换为日期对象:
```python
df['datetime'] = pd.to_datetime(df['timestamp'], unit='s')
```

4. 获取日期部分:
```python
df['date'] = df['datetime'].dt.date
```

以下是完整的代码示例:

```python
import pandas as pd

# 创建一个包含时间戳的DataFrame
data = {'timestamp': [1597962000, 1597958000, 1597954000]}
df = pd.DataFrame(data)

# 将时间戳转换为日期对象
df['datetime'] = pd.to_datetime(df['timestamp'], unit='s')

# 获取日期部分
df['date'] = df['datetime'].dt.date

print(df)
```

输出:

```
       timestamp         datetime     date
0  1597962000 2020-08-21 13:20:00 2020-08-21
1  1597958000 2020-08-21 12:40:00 2020-08-21
2  1597954000 2020-08-21 12:10:00 2020-08-21
```

这个例子展示了如何使用pandas将时间戳转换为日期对象。如果需要,我们可以添加更多的列来获取更多的时间信息,比如小时、分钟和秒。

如果要测试这个函数,可以使用以下测试用例:

```python
def test_timestamp_to_date():
    data = {'timestamp': [1597962000, 1597958000, 1597954000]}
    df = pd.DataFrame(data)
    df['datetime'] = pd.to_datetime(df['timestamp'], unit='s')
    df['date'] = df['datetime'].dt.date

    assert df.iloc[0]['date'] == pd.Timestamp('2020-08-21').date()
    assert df.iloc[1]['date'] == pd.Timestamp('2020-08-21').date()
    assert df.iloc[2]['date'] == pd.Timestamp('2020-08-21').date()

test_timestamp_to_date()
```

这个测试用例检查了是否正确地将时间戳转换为日期。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

潮易

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值