繁体   English   中英

Pandas 中的用户输入日期偏移

[英]User input date shift in Pandas

我有一个 dataframe,df,我希望用户在其中输入一个 integer,它将针对给定条件移动特定日期。

数据

         start      m1          m2          de          re          type
0       2018-01-01  2022-01-01  2022-04-01  2022-05-01  2022-06-01  aa
1       2018-01-01  2022-01-01  2022-04-01  2022-05-01  2022-06-01  aa
2       2018-01-01  2022-01-01  2022-04-01  2022-05-01  2022-06-01  bb

期望的

     **User input**: 9

        start       m1          m2          de          re          type
0       2018-01-01  2022-10-01  2023-01-01  2023-02-01  2023-03-01  aa
1       2018-01-01  2022-10-01  2023-01-01  2023-02-01  2023-03-01  aa
2       2018-01-01  2022-10-01  2023-01-01  2022-05-01  2022-06-01  bb

#user 输入 integer:9。我们现在在 2023 年 1 月 1 日的 'm2' 列 4+9 中添加 9 到月份。

(2022 年 4 月 1 日在“m2”列中。我们将 9 个月添加到该日期,即 2023 年 1 月 1 日)

正在做

month_value = df["m2"] += pd.DateOffset(months=int(input()))


 if(df[type] == 'aa'):                                  #condition applied

         d = {
             'm1': pd.DateOffset(months=3),             #we offset m1, 3 months from m2
             'de': pd.DateOffset(months=1),
             're': pd.DateOffset(months=2),
             }
        s = pd.Series(d).rsub(month_value)
        df.assign(**{**s, 'm2': month_value})
    else:
         e = {
             'm1': pd.DateOffset(months=3),
        
             }
        s1 = pd.Series(e).rsub(month_value)
        df.assign(**{**s1, 'm2': month_value})

我正在研究。 任何建议表示赞赏。

您可以为此使用 lambda function :

import pandas as pd

df = pd.DataFrame({'m1': [pd.Timestamp('2022-10-01'), pd.Timestamp('2022-10-01'), pd.Timestamp('2022-10-01')], 
                   'm2': [pd.Timestamp('2022-04-01'), pd.Timestamp('2022-04-01'), pd.Timestamp('2022-04-01')],  
                   'de': [pd.Timestamp('2023-02-01'), pd.Timestamp('2023-02-01'), pd.Timestamp('2022-05-01')],   
                   're': [pd.Timestamp('2023-03-01'), pd.Timestamp('2023-03-01'), pd.Timestamp('2022-06-01')], 
                   'type': ['aa', 'aa', 'bb']})

df["m2"] += pd.DateOffset(months=int(input('Offset: ')))

# Shift the dependent columns m1, de, re when type is 'aa'
df[df.type == 'aa'] = df[df.type == 'aa'].assign(m1 = lambda row: row['m2'] - pd.DateOffset(months=3))
df[df.type == 'aa'] = df[df.type == 'aa'].assign(de = lambda row: row['m2'] + pd.DateOffset(months=1))
df[df.type == 'aa'] = df[df.type == 'aa'].assign(re = lambda row: row['m2'] + pd.DateOffset(months=2))

# Shift only m1 when type is not 'aa'
df[df.type != 'aa'] = df[df.type != 'aa'].assign(m1 = lambda row: row['m2'] - pd.DateOffset(months=3))

print(df)

您可以使用 MonthOffset 将用户输入月份添加到所需列

df = pd.DataFrame({'m1': [pd.Timestamp('2022-10-01'), pd.Timestamp('2022-10-01'), pd.Timestamp('2022-10-01')], 
                   'm2': [pd.Timestamp('2022-04-01'), pd.Timestamp('2022-04-01'), pd.Timestamp('2022-04-01')], 
                   'type': ['aa', 'aa', 'bb']})    

user_input = 9
df['m2'] = df['m2'] + pd.offsets.MonthOffset(user_input)

你得到

    m1          m2          type
0   2022-10-01  2023-01-01  aa
1   2022-10-01  2023-01-01  aa
2   2022-10-01  2023-01-01  bb

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM