0

0

Pandas: 基于最近时间戳合并两个 DataFrame

聖光之護

聖光之護

发布时间:2025-09-11 22:22:19

|

365人浏览过

|

来源于php中文网

原创

pandas: 基于最近时间戳合并两个 dataframe

本文介绍了如何使用 Pandas 的 merge_asof 函数,基于时间戳的近似匹配将两个 DataFrame 进行合并。通过示例代码详细展示了该函数的用法,包括处理时间序列数据、排序以及控制合并方式等,旨在帮助读者掌握在 Pandas 中进行时间序列数据对齐和合并的有效方法。

在数据分析中,经常会遇到需要将两个 DataFrame 基于时间戳进行合并的情况。然而,两个 DataFrame 中的时间戳往往并不完全一致,此时就需要找到最接近的时间戳进行匹配。Pandas 提供的 merge_asof 函数可以很好地解决这个问题。

merge_asof 函数详解

merge_asof 函数用于执行近似连接(asof join)。它要求两个 DataFrame 必须先按照连接键(通常是时间戳)进行排序。然后,对于左侧 DataFrame 的每一行,merge_asof 会在右侧 DataFrame 中找到小于等于(或大于等于,取决于 direction 参数)连接键的最近一行,并将两行合并。

函数签名如下:

pd.merge_asof(left, right, on=None, left_on=None, right_on=None, left_index=False, right_index=False, by=None, left_by=None, right_by=None, tolerance=None, direction='backward', suffixes=('_x', '_y'), allow_exact_matches=True, indicator=False)

常用参数解释:

  • left: 左侧 DataFrame。
  • right: 右侧 DataFrame。
  • on: 用于连接的列名,如果 left_on 和 right_on 都未指定,则使用此参数。
  • left_on: 左侧 DataFrame 用于连接的列名。
  • right_on: 右侧 DataFrame 用于连接的列名。
  • left_index: 如果为 True,则使用左侧 DataFrame 的索引作为连接键。
  • right_index: 如果为 True,则使用右侧 DataFrame 的索引作为连接键。
  • direction: 连接方向,可选值包括 'backward' (默认), 'forward', 和 'nearest'。
    • 'backward': 使用小于等于连接键的最近一行。
    • 'forward': 使用大于等于连接键的最近一行。
    • 'nearest': 使用最接近连接键的行。
  • tolerance: 可选参数,指定最大时间差,超过此时间差的匹配将被忽略。

使用示例

假设我们有两个 DataFrame,df1 和 df2,它们都包含时间戳和数据列。我们的目标是找到 df1 中每个时间戳在 df2 中最接近的时间戳,并将 df2 中对应的数据添加到 df1 中。

import pandas as pd

df1 = pd.DataFrame({'Time1': ['2023-11-30 13:01:51.813', 
                              '2023-11-28 10:01:51.760', 
                              '2023-11-28 10:01:51.347', 
                              '2023-11-27 10:01:51.320', 
                              '2023-11-26 10:01:51.260'], 
                    'Data1': [2, 4, 6, 8, 10]})

df2 = pd.DataFrame({'Time2': ['2023-11-30 10:00:03.733', 
                              '2023-11-29 08:00:03.767', 
                              '2023-11-28 16:00:03.523', 
                              '2023-11-27 14:00:03.827', 
                              '2023-11-26 12:00:03.417'], 
                    'Data2': ['A', 'B', 'C', 'D', 'E']})

# 将时间字符串转换为 datetime 对象
df1['Time1'] = pd.to_datetime(df1['Time1'], format='%Y-%m-%d %H:%M:%S.%f')
df2['Time2'] = pd.to_datetime(df2['Time2'], format='%Y-%m-%d %H:%M:%S.%f')

# 按照时间戳排序
df1 = df1.sort_values(by=['Time1'])
df2 = df2.sort_values(by=['Time2'])

# 使用 merge_asof 函数进行合并
df3 = pd.merge_asof(left=df1, right=df2, left_on='Time1', right_on='Time2', direction='nearest')

print(df3)

这段代码首先将 Time1 和 Time2 列转换为 datetime 对象,然后按照时间戳进行排序。最后,使用 merge_asof 函数,指定 left_on 和 right_on 参数为时间戳列,direction 参数为 'nearest',表示找到最接近的时间戳进行匹配。

如果希望将时间戳列设置为索引,可以这样做:

论论App
论论App

AI文献搜索、学术讨论平台,涵盖了各类学术期刊、学位、会议论文,助力科研。

下载
import pandas as pd

df1 = pd.DataFrame({'Time1': ['2023-11-30 13:01:51.813', 
                              '2023-11-28 10:01:51.760', 
                              '2023-11-28 10:01:51.347', 
                              '2023-11-27 10:01:51.320', 
                              '2023-11-26 10:01:51.260'], 
                    'Data1': [2, 4, 6, 8, 10]})

df2 = pd.DataFrame({'Time2': ['2023-11-30 10:00:03.733', 
                              '2023-11-29 08:00:03.767', 
                              '2023-11-28 16:00:03.523', 
                              '2023-11-27 14:00:03.827', 
                              '2023-11-26 12:00:03.417'], 
                    'Data2': ['A', 'B', 'C', 'D', 'E']})

# 将时间字符串转换为 datetime 对象
df1['Time1'] = pd.to_datetime(df1['Time1'], format='%Y-%m-%d %H:%M:%S.%f')
df2['Time2'] = pd.to_datetime(df2['Time2'], format='%Y-%m-%d %H:%M:%S.%f')

# 按照时间戳排序
df1 = df1.sort_values(by=['Time1'])
df2 = df2.sort_values(by=['Time2'])

# 将时间戳列设置为索引
df1 = df1.set_index('Time1')
df2 = df2.set_index('Time2')

# 使用 merge_asof 函数进行合并
df3 = pd.merge_asof(left=df1, right=df2, left_index=True, right_index=True, direction='nearest')

print(df3)

在这个例子中,我们使用 left_index=True 和 right_index=True 参数,告诉 merge_asof 函数使用索引作为连接键。

注意事项

  • 排序: 使用 merge_asof 函数之前,务必确保两个 DataFrame 已经按照连接键进行了排序。否则,结果可能不正确。

  • 数据类型: 连接键的数据类型应该一致,通常是 datetime 对象。

  • 连接方向: 根据实际需求选择合适的 direction 参数。

  • 索引与列: 可以选择使用列作为连接键,也可以选择使用索引。

  • 只合并特定列: 如果只需要合并特定的列,可以在调用 merge_asof 之前,先选择需要的列。例如:

    df3 = pd.merge_asof(left=df1[['Time1', 'Data1']], right=df2[['Time2', 'Data2']], left_on='Time1', right_on='Time2', direction='nearest')

总结

merge_asof 函数是 Pandas 中一个强大的工具,可以方便地基于时间戳的近似匹配将两个 DataFrame 进行合并。通过掌握该函数的用法,可以有效地处理时间序列数据,并进行更深入的分析。在实际应用中,需要注意排序、数据类型、连接方向等细节,以确保结果的准确性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python 时间序列分析与预测
Python 时间序列分析与预测

本专题专注讲解 Python 在时间序列数据处理与预测建模中的实战技巧,涵盖时间索引处理、周期性与趋势分解、平稳性检测、ARIMA/SARIMA 模型构建、预测误差评估,以及基于实际业务场景的时间序列项目实操,帮助学习者掌握从数据预处理到模型预测的完整时序分析能力。

71

2025.12.04

Python 数据清洗与预处理实战
Python 数据清洗与预处理实战

本专题系统讲解 Python 在数据清洗与预处理中的核心技术,包括使用 Pandas 进行缺失值处理、异常值检测、数据格式化、特征工程与数据转换,结合 NumPy 高效处理大规模数据。通过实战案例,帮助学习者掌握 如何处理混乱、不完整数据,为后续数据分析与机器学习模型训练打下坚实基础。

1

2026.01.31

数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

310

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

222

2025.10.31

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

59

2026.01.31

高干文在线阅读网站大全
高干文在线阅读网站大全

汇集热门1v1高干文免费阅读资源,涵盖都市言情、京味大院、军旅高干等经典题材,情节紧凑、人物鲜明。阅读专题下面的文章了解更多详细内容。

43

2026.01.31

无需付费的漫画app大全
无需付费的漫画app大全

想找真正免费又无套路的漫画App?本合集精选多款永久免费、资源丰富、无广告干扰的优质漫画应用,涵盖国漫、日漫、韩漫及经典老番,满足各类阅读需求。阅读专题下面的文章了解更多详细内容。

60

2026.01.31

漫画免费在线观看地址大全
漫画免费在线观看地址大全

想找免费又资源丰富的漫画网站?本合集精选2025-2026年热门平台,涵盖国漫、日漫、韩漫等多类型作品,支持高清流畅阅读与离线缓存。阅读专题下面的文章了解更多详细内容。

12

2026.01.31

漫画防走失登陆入口大全
漫画防走失登陆入口大全

2026最新漫画防走失登录入口合集,汇总多个稳定可用网址,助你畅享高清无广告漫画阅读体验。阅读专题下面的文章了解更多详细内容。

13

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.4万人学习

Pandas 教程
Pandas 教程

共15课时 | 1.0万人学习

ASP 教程
ASP 教程

共34课时 | 4.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号