Pandas時間差timedelta詳解

一、什麼是Pandas時間差timedelta?

在Pandas中,timedelta是指兩個時間值之間的差值。

一般情況下,Pandas自動推斷時間差單位,可以是天、小時、分鐘、秒、毫秒、微秒、納秒。

timedelta是由兩個datetime之間的差來表示的,datetime可以是Series或DataFrame中的一組值。

二、Pandas時間差的創建

可以通過直接進行時間差運算創建時間差對象:

import pandas as pd
from datetime import datetime

t1 = datetime(2021, 6, 10)
t2 = datetime(2021, 6, 12)
delta = t2 - t1
print(delta)

輸出結果為:

2 days, 0:00:00

也可以使用Pandas的Timedelta函數來創建時間差對象:

import pandas as pd

delta = pd.Timedelta('2 days 12 hours 5 minutes 10 seconds')
print(delta)

輸出結果為:

2 days 12:05:10

三、Pandas時間差的運算

Pandas時間差支持加、減、乘、除等運算符的操作。

在Series或DataFrame上進行時間差的運算,會自動對每個元素進行運算:

import pandas as pd

data = pd.DataFrame({'date1': pd.date_range('2022-01-01', periods=3), 'date2': pd.date_range('2022-01-04', periods=3)})
data['timedelta'] = data['date1'] - data['date2']
print(data)

輸出結果為:

date1 date2 timedelta

0 2022-01-01 2022-01-04 -3 days

1 2022-01-02 2022-01-05 -3 days

2 2022-01-03 2022-01-06 -3 days

也可以對時間差對象進行加、減、乘、除的運算:

import pandas as pd

delta1 = pd.Timedelta('2 days 12 hours 5 minutes 10 seconds')
delta2 = pd.Timedelta('1 day 10 hours')
print(delta1 + delta2)  # 加法運算
print(delta1 - delta2)  # 減法運算
print(delta1 * 2)       # 乘法運算
print(delta1 / 2)       # 除法運算

輸出結果為:

3 days 22:05:10

1 days 2:05:10

5 days 0:10:20

1 days 6:02:35

四、Pandas時間差的屬性和方法

Pandas時間差對象有許多有用的屬性和方法。

1)屬性:

  • days: 返回時間差中天的數量。
  • seconds: 返回時間差中秒的數量(去除天后的秒數)。
  • microseconds: 返回時間差中微秒的數量(去除天和秒後的微秒數)。
  • nanoseconds: 返回時間差中納秒的數量(去除天、秒和微秒後的納秒數)。

2)方法:

  • floor(單位): 對時間差對象的各個時間數值向下取整。
  • ceil(單位): 對時間差對象的各個時間數值向上取整。
  • round(單位): 對時間差對象的各個時間數值四捨五入取整。

以seconds為例:

import pandas as pd

delta = pd.Timedelta('2 days 12 hours 5 minutes 10 seconds')
print(delta.seconds)    # 返回除天數外的秒數
print(delta.floor('hours'))    # hours向下取整,返回2 days 12:00:00
print(delta.ceil('days'))      # days向上取整,返回3 days
print(delta.round('minutes'))  # minutes四捨五入,返回2 days 12:05:00

輸出結果為:

43510

2 days 12:00:00

3 days

2 days 12:05:00

總結

Pandas的timedelta可以方便地對時間差進行運算和轉換,對於時間序列數據的分析和處理非常有用。

在實際的工作中,我們可以利用timedelta來計算時間差、增加或減少日期等操作。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/301792.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-30 16:09
下一篇 2024-12-30 16:09

相關推薦

  • Pandas下載whl指南

    本篇文章將從幾個方面為大家詳細解答如何下載Pandas的whl文件。 一、Pandas簡介 Pandas是一個基於Python的軟件庫,主要用於數據分析、清洗和處理。在數據處理方面…

    編程 2025-04-28
  • 如何在Python中安裝和使用Pandas

    本文將介紹如何安裝和使用Python的Pandas庫 一、Pandas庫的介紹 Pandas是Python的一個數據分析庫,提供了許多實用的數據結構和數據分析工具,可以幫助用戶輕鬆…

    編程 2025-04-27
  • Linux sync詳解

    一、sync概述 sync是Linux中一個非常重要的命令,它可以將文件系統緩存中的內容,強制寫入磁盤中。在執行sync之前,所有的文件系統更新將不會立即寫入磁盤,而是先緩存在內存…

    編程 2025-04-25
  • 神經網絡代碼詳解

    神經網絡作為一種人工智能技術,被廣泛應用於語音識別、圖像識別、自然語言處理等領域。而神經網絡的模型編寫,離不開代碼。本文將從多個方面詳細闡述神經網絡模型編寫的代碼技術。 一、神經網…

    編程 2025-04-25
  • Linux修改文件名命令詳解

    在Linux系統中,修改文件名是一個很常見的操作。Linux提供了多種方式來修改文件名,這篇文章將介紹Linux修改文件名的詳細操作。 一、mv命令 mv命令是Linux下的常用命…

    編程 2025-04-25
  • Python安裝OS庫詳解

    一、OS簡介 OS庫是Python標準庫的一部分,它提供了跨平台的操作系統功能,使得Python可以進行文件操作、進程管理、環境變量讀取等系統級操作。 OS庫中包含了大量的文件和目…

    編程 2025-04-25
  • Python輸入輸出詳解

    一、文件讀寫 Python中文件的讀寫操作是必不可少的基本技能之一。讀寫文件分別使用open()函數中的’r’和’w’參數,讀取文件…

    編程 2025-04-25
  • 詳解eclipse設置

    一、安裝與基礎設置 1、下載eclipse並進行安裝。 2、打開eclipse,選擇對應的工作空間路徑。 File -> Switch Workspace -> [選擇…

    編程 2025-04-25
  • nginx與apache應用開發詳解

    一、概述 nginx和apache都是常見的web服務器。nginx是一個高性能的反向代理web服務器,將負載均衡和緩存集成在了一起,可以動靜分離。apache是一個可擴展的web…

    編程 2025-04-25
  • git config user.name的詳解

    一、為什麼要使用git config user.name? git是一個非常流行的分布式版本控制系統,很多程序員都會用到它。在使用git commit提交代碼時,需要記錄commi…

    編程 2025-04-25

發表回復

登錄後才能評論