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',表示找到最接近的时间戳进行匹配。

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

Pixso AI
Pixso AI

Pixso AI是一款智能生成设计稿工具,通过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 模型构建、预测误差评估,以及基于实际业务场景的时间序列项目实操,帮助学习者掌握从数据预处理到模型预测的完整时序分析能力。

68

2025.12.04

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

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

309

2023.10.31

php数据类型
php数据类型

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

222

2025.10.31

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

4

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

2

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

1

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

1

2026.01.30

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

20

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

16

2026.01.29

热门下载

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

精品课程

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

共58课时 | 4.3万人学习

Pandas 教程
Pandas 教程

共15课时 | 1.0万人学习

ASP 教程
ASP 教程

共34课时 | 4.2万人学习

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

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