Django 每天午夜在后台更新静态 csv 文件
Django update a static csv file in background everyday at midnight
你好我想每天午夜在我的django网页后台自动更新一个静态csv文件,我尝试设置一个后台任务,这样文件每天午夜都会更新,为了测试它我会将计划值更改为 1s,这样我就可以看到它发生得更快,但任务永远不会执行,或者至少我从未在 google devtool 或命令行终端中看到任何打印,修改后也没有任何变化文件属性中的日期
我的后台任务
@background(schedule= abs(datetime.datetime.now() - datetime.datetime.now().replace(minute=0, second=0, hour=0)))
def update():
print("in update")
apiurl = 'https://api_im_downloading_from'
jasonObject = requests.get(apiurl)
parsed = json.loads(jasonObject.text)
print("downloaded")
file = open('boards/static/csv_files/file.csv', 'w+', newline='')
df = pd.json_normalize(parsed) #store parsed jason in a panda data frame
df.to_csv(r'boards/static/csv_files/file.csv', index=False)
file.close()
update()
我的settings.py文件
INSTALLED_APPS = [
'boards.apps.BoardsConfig',
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'background_task',
]
当我不使用@background 而只是正常调用我的方法时,服务器崩溃了,我还尝试导入调度模块并使用
schedule.every().day.at("0:0").do(update) #change time value to execute faster
我也在命令行中运行这个,但什么也没发生
python manage.py process_tasks
编辑
我也 运行 一个 cronjob
class MyCronJob(CronJobBase):
RUN_EVERY_MINS = 1 # every minute
schedule = Schedule(run_every_mins=RUN_EVERY_MINS)
code = 'my_cron_job' # a unique code
def do(self):
print("in chron job every minute")
update()
但是 cronjob 要求我在命令行中 运行 python manage.py runcrons
做一些事情,但我想要的是每次我 运行 服务器使用 python manage.py runserver
通过使用bat文件解决了运行任务在windows任务调度器中的任务,详情可以在下面找到link
你好我想每天午夜在我的django网页后台自动更新一个静态csv文件,我尝试设置一个后台任务,这样文件每天午夜都会更新,为了测试它我会将计划值更改为 1s,这样我就可以看到它发生得更快,但任务永远不会执行,或者至少我从未在 google devtool 或命令行终端中看到任何打印,修改后也没有任何变化文件属性中的日期
我的后台任务
@background(schedule= abs(datetime.datetime.now() - datetime.datetime.now().replace(minute=0, second=0, hour=0)))
def update():
print("in update")
apiurl = 'https://api_im_downloading_from'
jasonObject = requests.get(apiurl)
parsed = json.loads(jasonObject.text)
print("downloaded")
file = open('boards/static/csv_files/file.csv', 'w+', newline='')
df = pd.json_normalize(parsed) #store parsed jason in a panda data frame
df.to_csv(r'boards/static/csv_files/file.csv', index=False)
file.close()
update()
我的settings.py文件
INSTALLED_APPS = [
'boards.apps.BoardsConfig',
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'background_task',
]
当我不使用@background 而只是正常调用我的方法时,服务器崩溃了,我还尝试导入调度模块并使用
schedule.every().day.at("0:0").do(update) #change time value to execute faster
我也在命令行中运行这个,但什么也没发生
python manage.py process_tasks
编辑 我也 运行 一个 cronjob
class MyCronJob(CronJobBase):
RUN_EVERY_MINS = 1 # every minute
schedule = Schedule(run_every_mins=RUN_EVERY_MINS)
code = 'my_cron_job' # a unique code
def do(self):
print("in chron job every minute")
update()
但是 cronjob 要求我在命令行中 运行 python manage.py runcrons
做一些事情,但我想要的是每次我 运行 服务器使用 python manage.py runserver
通过使用bat文件解决了运行任务在windows任务调度器中的任务,详情可以在下面找到link