与数据框值匹配的用户输入

时间:2019-12-05 14:36:34

标签: python datetime user-input

我正在尝试根据某种格式(例如MM / YYYY)获取用户的日期输入,我希望它循环播放直到用户提供格式正确且在数据日期范围内的输入设置。

我已经尝试了以下代码,但是它似乎没有达到我的预期。 抱歉,我是Python的新手,我不确定如何将代码修改为期望的结果。

import pandas as pd
from datetime import datetime
import numpy as  np

date_rng = pd.date_range(start = '1/12/2016', end='01/08/2019', freq='M')
df = pd.DataFrame(date_rng, columns=['Date'])
df['Col1'] = np.random.randn(len(df['Date']))
df['Date'] = df['Date'].dt.strftime('%m/%Y')

is_Valid = False
while not is_Valid:
    start_dt = input('Input start date between ' + df.iloc[0,0] + ' & '  + df.iloc[-1,0])
    try:
        ui = datetime.datetime.strptime(start_dt,'%m/%Y')
        is_Valid = True
        for dts in df['Date']:
            if start_dt == dts:
                print('OKAY')
            else:
                start_dt = input('Out of Range. Try Again.')
    except:
        print('Wrong Format. Try again')

1 个答案:

答案 0 :(得分:1)

我认为您快到那里了,只需进行一下小调整即可。日期时间对象可以在逻辑上与范围进行比较。当然,如果您希望它继续循环,则可能需要重置is_Valid标志

import pandas as pd
import datetime as dt
import numpy as  np

date_rng = pd.date_range(start = '1/12/2016', end='01/08/2019', freq='M')
df = pd.DataFrame(date_rng, columns=['Date'])
df['Col1'] = np.random.randn(len(df['Date']))
df['Date'] = df['Date'].dt.strftime('%m/%Y')

is_Valid = False
while not is_Valid:
    start_dt = input('Input start date between ' + df.iloc[0,0] + ' & '  + df.iloc[-1,0] + ' -  :')
    try:
        ui = dt.datetime.strptime(start_dt,'%m/%Y')
        is_Valid = True
        if (ui<=max(date_rng)) & (ui>=min(date_rng)):
            print("Okay")
        else:
            start_dt = input('Out of Range. Try Again.')
            is_Valid = False
    except:
        print('Wrong Format. Try again')
        is_Valid = False