Python处理表格日期的常用场景和方法

 更新时间:2025年12月22日 09:20:28   作者:LucaTech  
这篇文章主要介绍了如何在pandas中处理日期和时间数据,包括提取日期信息、计算时间差、将日期列设为索引、日期格式转换为字符串以及字符串转换为日期格式,需要的朋友可以参考下

1. 提取日期

有时候我们只需要从日期中提取出年、月、日等信息,以便更好地进行数据分析和可视化。可以使用dt属性实现:

# 创建一个数据集
df = pd.DataFrame({'date': ['2019-05-01 10:00:00', '2020-07-12 12:00:00', '2022-08-10 14:00:00'],
                   'value': [1, 2, 3]})

# 将日期列转化为时间格式
df['date'] = pd.to_datetime(df['date'])

# 提取年份
df['year'] = df['date'].dt.year

# 提取月份
df['month'] = df['date'].dt.month

# 提取日
df['day'] = df['date'].dt.day

# 输出数据集
print(df)

2. 计算时间差

在时间序列分析中,我们通常需要计算时间差,例如两个日期之间的天数、小时数等。可以使用timedelta实现:

# 创建一个数据集
df = pd.DataFrame({'date': ['2019-05-01 10:00:00', '2020-07-12 12:00:00', '2022-08-10 14:00:00'],
                   'value': [1, 2, 3]})

# 将日期列转化为时间格式
df['date'] = pd.to_datetime(df['date'])

# 计算两个日期之间的天数
df['days_diff'] = (df['date'] - df['date'].min()).dt.days

# 计算两个日期之间的月份数
df['months_diff'] = (df['date'].dt.year - df['date'].min().year) * 12 + (df['date'].dt.month - df['date'].min().month)

# 计算两个日期之间的年份数
df['years_diff'] = (df['date'].dt.year - df['date'].min().year)

# 输出数据集
print(df)

3. 将日期列设为索引

在时间序列分析中,我们通常需要将日期列设为索引,以便更好地进行数据分析和可视化。可以使用set_index()函数实现:

# 创建一个数据集
df = pd.DataFrame({'date': ['2019-05-01 10:00:00', '2020-07-12 12:00:00', '2022-08-10 14:00:00'],
                   'value': [1, 2, 3]})


# 将日期列转化为时间格式
df['date'] = pd.to_datetime(df['date'])


# 将日期列设为索引
df = df.set_index('date')


# 输出数据集
print(df)

4. dataframe: 日期格式转字符串

可以使用strftime()函数将日期格式的列转为字符串。

strftime()函数中,%Y表示四位数的年份,%m表示两位数的月份,%d表示两位数的日期。可以根据需要进行调整。

下面是一个使用示例:

#如何使用strftime 

# 创建一个包含日期的dataframe
df = pd.DataFrame({'date': ['2021-10-01', '2021-10-02', '2021-10-03']})

# 将日期列转换为日期格式
df['date'] = pd.to_datetime(df['date'])

# 将日期格式的列转为字符串
df['date'] = df['date'].dt.strftime('%Y-%m-%d')

# 输出dataframe
print(df)

5. 字符串转日期格式

5.1 dataframe:字符串转日期格式 - pd.to_datetime函数

pd.to_datetime()函数是pandas中用于将字符串或者数字转化为时间格式的函数。该函数通常用于将数据集中的时间列转化为pandas能够识别的时间格式,以便更好地进行数据分析和时间序列分析。

下面是使用pd.to_datetime()函数的一个例子:

import pandas as pd

# 创建一个包含日期文本的dataframe
df = pd.DataFrame({'date': ['2021-10-01', '2021-10-02', '2021-10-03']})

# 将日期列转换为日期格式
df['date'] = pd.to_datetime(df['date'])

# 输出dataframe
print(df)

5.2 dataframe:字符串转日期格式 - strptime

除了pd.to_datetime()函数,还可以使用Python中的datetime模块中的datetime.strptime()函数将字符串转为日期格式。

下面是一个使用datetime.strptime()函数的例子:

import pandas as pd
from datetime import datetime

# 创建一个包含日期文本的dataframe
df = pd.DataFrame({'date_str': ['2021-10-01', '2021-10-02', '2021-10-03']})

# 将日期列转换为日期格式
df['date'] = df['date_str'].apply(lambda x: datetime.strptime(x, '%Y-%m-%d'))

# 输出dataframe
print(df)

在datetime.strptime()函数中,第一个参数是要转换的字符串,第二个参数是字符串的格式。例如,%Y表示四位数的年份,%m表示两位数的月份,%d表示两位数的日期。可以根据需要进行调整。

pd.to_datetime()函数在处理日期时更加灵活和方便,因此一般情况下建议使用pd.to_datetime()函数。

到此这篇关于Python处理表格日期的常用场景和方法的文章就介绍到这了,更多相关Python处理表格日期内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python3实现生成随机密码的方法

    Python3实现生成随机密码的方法

    这篇文章主要介绍了Python3实现生成随机密码的方法,是Python程序设计中非常实用的一个技巧,需要的朋友可以参考下
    2014-08-08
  • 使用Django框架创建项目

    使用Django框架创建项目

    这篇文章介绍了使用Django框架创建项目的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • Pythony运维入门之Socket网络编程详解

    Pythony运维入门之Socket网络编程详解

    这篇文章主要介绍了Pythony运维入门之Socket网络编程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • python sklearn库实现简单逻辑回归的实例代码

    python sklearn库实现简单逻辑回归的实例代码

    Scikit-learn(sklearn)是机器学习中常用的第三方模块,对常用的机器学习方法进行了封装,这篇文章主要介绍了python sklearn库实现简单逻辑回归的实例代码,需要的朋友可以参考下
    2019-07-07
  • Python常用数据类型之列表使用详解

    Python常用数据类型之列表使用详解

    列表是Python中的基础数据类型之一,其他语言中也有类似于列表的数据类型,比如js中叫数组,他是以[ ]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型。本文将通过示例详细讲解列表的使用,需要的可以参考一下
    2022-04-04
  • Python高效计算上周五到任意日期的完全指南

    Python高效计算上周五到任意日期的完全指南

    在业务系统开发中,日期计算是高频且关键的需求,这篇文章将高效计算上周五到任意日期的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下
    2025-08-08
  • Python操作Excel工作簿的示例代码(\*.xlsx)

    Python操作Excel工作簿的示例代码(\*.xlsx)

    这篇文章主要介绍了Python操作Excel工作簿的示例代码(\*.xlsx),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-03-03
  • django框架cookie和session用法实例详解

    django框架cookie和session用法实例详解

    这篇文章主要介绍了django框架cookie和session用法,结合实例形式详细分析了Django框架cookie和session的功能、原理、使用方法及相关操作注意事项,需要的朋友可以参考下
    2019-12-12
  • Python文档生成工具pydoc使用介绍

    Python文档生成工具pydoc使用介绍

    这篇文章主要介绍了Python文档生成工具pydoc使用介绍,本文讲解了基本用法、获取帮助的方法、生成的文档效果图等内容,需要的朋友可以参考下
    2015-06-06
  • Pandas根据条件实现替换列中的值

    Pandas根据条件实现替换列中的值

    在使用Pandas的Python中,DataFrame列中的值可以通过使用各种内置函数根据条件进行替换,本文主要来和大家讨论在Pandas中用条件替换数据集列中的值的各种方法,希望对大家有所帮助
    2024-01-01

最新评论