Panda's: hoe timedelta in maanden te berekenen
U kunt de volgende functie gebruiken om een tijdsverschil in maanden tussen twee kolommen van een panda’s DataFrame te berekenen:
def month_diff(x, y): end = x. dt . to_period (' M '). view (dtype=' int64 ') start = y. dt . to_period (' M '). view (dtype=' int64 ') return end-start
Het volgende voorbeeld laat zien hoe u deze functie in de praktijk kunt gebruiken.
Voorbeeld: Bereken Timedelta in maanden in Panda’s
Stel dat we de volgende panda’s DataFrame hebben:
import pandas as pd #createDataFrame df = pd. DataFrame ({' event ': ['A', 'B', 'C'], ' start_date ': ['20210101', '20210201', '20210401'], ' end_date ': ['20210608', '20210209', '20210801'] }) #convert start date and end date columns to datetime df[' start_date '] = pd. to_datetime (df[' start_date ']) df[' end_date '] = pd. to_datetime (df[' end_date ']) #view DataFrame print (df) event start_date end_date 0 A 2021-01-01 2021-06-08 1 B 2021-02-01 2021-02-09 2 C 2021-04-01 2021-08-01
Stel nu dat we de tijdsdelta (in maanden) tussen de kolommen startdatum en einddatum willen berekenen.
Om dit te doen, zullen we eerst de volgende functie definiëren:
#define function to calculate time delta in months between two columns def month_diff(x, y): end = x. dt . to_period (' M '). view (dtype=' int64 ') start = y. dt . to_period (' M '). view (dtype=' int64 ') return end-start
Vervolgens gebruiken we deze functie om de tijdsdelta in maanden tussen de kolommen startdatum en einddatum te berekenen:
#calculate month difference between start date and end date columns
df[' month_difference '] = month_diff(df. end_date , df. start_date )
#view updated DataFrame
df
event start_date end_date month_difference
0 A 2021-01-01 2021-06-08 5
1 B 2021-02-01 2021-02-09 0
2 C 2021-04-01 2021-08-01 4
De kolom Month_difference geeft het tijdsverschil (in maanden) weer tussen de kolommen startdatum en einddatum .
Aanvullende bronnen
In de volgende tutorials wordt uitgelegd hoe u andere veelvoorkomende bewerkingen in panda’s kunt uitvoeren:
Hoe kolommen naar DateTime in Pandas te converteren
Hoe DateTime naar datum te converteren in Pandas
Hoe maand uit datum te extraheren in Panda’s