Я искал способ вызова различных функций на основе переменной, и я придумал это сопоставление словаря. Интересно, есть ли способ как-то улучшить его и сделать менее повторяющимся?
def schedule_on_monday(time):
schedule.every().monday.at(time).do(job)
def schedule_on_tuesday(time):
schedule.every().tuesday.at(time).do(job)
def schedule_on_wednesday(time):
schedule.every().wednesday.at(time).do(job)
def schedule_on_thursday(time):
schedule.every().thursday.at(time).do(job)
def schedule_on_friday(time):
schedule.every().friday.at(time).do(job)
def schedule_on_saturday(time):
schedule.every().saturday.at(time).do(job)
def schedule_on_sunday(time):
schedule.every().sunday.at(time).do(job)
def schedule_tasks(day, time):
switcher = {
'monday': schedule_on_monday,
'tuesday': schedule_on_tuesday,
'wednesday': schedule_on_wednesday,
'thursday' : schedule_on_thursday,
'friday' : schedule_on_friday,
'saturday' : schedule_on_saturday,
'sunday' : schedule_on_sunday
}
func = switcher.get(day, lambda: "Invalid")
func(time)
Вы можете использовать getattr
, чтобы получить имя свойства из строки:
def schedule_tasks(day, time):
getattr(schedule.every(), day).at(time).do(job)
Вы можете попробовать использовать функцию exec:
def schedule_tasks(day, time):
exec("schedule.every().{0}.at({1}).do(job)".format(day, time))
@ Aplet123 Я бы даже этого не сказал, вы будете удивлены, что люди попробуют. Просто echo kaboom
или как там
В любом случае, неясно, является ли это проблемой, потому что неясно, связано ли это с ненадежным пользовательским вводом. Тем не менее, как правило, это дизайн, которого следует избегать независимо от того,
А тут пользователь проходит
__import__("os").system("rm /very_important_file")
и тебе грустно.