#python #django #virtualenv #pythonanywhere
Вопрос:
Я развернул свое приложение Django на pythonanuwhere и хочу добавить один файл в запланированные задачи. Но это дает мне ошибку:
django.ядро.исключения.Неправильно настроено: Запрошена настройка LOGGING_CONFIG, но параметры не настроены. Вы должны либо определить переменную среды DJANGO_SETTINGS_MODULE, либо вызвать settings.configure() перед доступом к настройкам.
Я попробовал это:
os.environ.setdefault('DJANGO_SETTING_MODULE', 'smsreminder.settings')
django.setup()
Результат тот же, но ошибка в строке с django.setup()
Скрипт в файле, который я хочу выполнить:
import datetime
from django_common.auth_backends import User
from reminder.models import Remind
from twilio.base.exceptions import TwilioRestException
from twilio.rest import Client
def my_scheduled_job():
content = Remind.objects.all()
account_sid = "--------------------------"
auth_token = "--------------------------"
for smscontent in content:
if smscontent.remind_date == datetime.today().date():
tempusers = User.objects.filter(username=smscontent.author)
for recipient in tempusers:
try:
client = Client(account_sid, auth_token)
message = client.messages.create(
body="I just want to remind, that you have some task for today {date}: {task}. {time} is the deadline!".format(
date=str(smscontent.remind_date), task=str(smscontent.title),
time=str(smscontent.remind_time)),
to=str(recipient.username),
from_=" 18568889437")
print(message.sid)
except TwilioRestException:
pass
return
Ошибка:
Traceback (most recent call last):
File "/home/remindmy/sms-reminder/reminder/cron.py", line 3, in <module>
from django_common.auth_backends import User
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django_common/auth_backends.py", line 6, in <module>
from django.contrib.auth.backends import ModelBackend
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/contrib/auth/backends.py", line 2, in <module>
from django.contrib.auth.models import Permission
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/contrib/auth/models.py", line 3, in <module>
from django.contrib.auth.base_user import AbstractBaseUser, BaseUserManager
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/contrib/auth/base_user.py", line 48, in <module>
class AbstractBaseUser(models.Model):
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/db/models/base.py", line 108, in __new__
app_config = apps.get_containing_app_config(module)
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/apps/registry.py", line 253, in get_containing_app_config
self.check_apps_ready()
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/apps/registry.py", line 135, in check_apps_ready
settings.INSTALLED_APPS
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/conf/__init__.py", line 82, in __getattr__
self._setup(name)
File "/home/remindmy/.virtualenvs/remindervenv/lib/python3.9/site-packages/django/conf/__init__.py", line 63, in _setup
raise ImproperlyConfigured(
django.core.exceptions.ImproperlyConfigured: Requested setting INSTALLED_APPS, but settings are not configured. You must either define the environment variable DJANGO_SETTINGS_MODULE or call settings.co
nfigure() before accessing settings.
Комментарии:
1. Хотя это возможно для запуска кода Django внутри запланированной задачи так, как вы пытаетесь это сделать, есть несколько проблем, о которых вам нужно позаботиться (например, убедиться, что путь задан правильно, что импорт выполнен в правильном порядке и т. Д.), Поэтому рекомендуется скорее написать команду управления и запустить ее как запланированную задачу.
2. Вот ссылка на документы Django по созданию команд управления, если это полезно: docs.djangoproject.com/en/3.2/howto/custom-management-commands
Ответ №1:
Сегодня я столкнулся с той же проблемой:
Как предполагает ошибка
django.core.exceptions.ImproperlyConfigured: Requested setting INSTALLED_APPS, but settings are not configured. You must either define the environment variable DJANGO_SETTINGS_MODULE or call settings.co
nfigure() before accessing settings.
НАСТРОЙКА S, а не НАСТРОЙКА. Таким образом, вам просто нужно обновить свой исходный код с заглавной буквы S
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'smsreminder.settings')
django.setup()