Forecast matching query does not exist.
Request Method: | GET |
---|---|
Request URL: | https://meteopoisk.ru/tunis/gammart/sea_temp/november.html |
Django Version: | 2.2.4 |
Exception Type: | DoesNotExist |
Exception Value: | Forecast matching query does not exist. |
Exception Location: | /home/meteopoisk/www/.venv/lib/python3.7/site-packages/django/db/models/query.py in get, line 408 |
Python Executable: | /home/meteopoisk/www/.venv/bin/python3.7 |
Python Version: | 3.7.4 |
Python Path: | ['/home/meteopoisk/www/.venv/bin', '/home/meteopoisk/www/project', '/home/meteopoisk/www/.venv/lib/python37.zip', '/home/meteopoisk/www/.venv/lib/python3.7', '/home/meteopoisk/www/.venv/lib/python3.7/lib-dynload', '/usr/local/lib/python3.7', '/home/meteopoisk/www/.venv/lib/python3.7/site-packages'] |
Server time: | Пт, 29 Мар 2024 15:54:55 +0000 |
/home/meteopoisk/www/.venv/lib/python3.7/site-packages/django/core/handlers/exception.py
in inner
This decorator is automatically applied to all middleware to ensure that
no middleware leaks an exception and that the next middleware in the stack
can rely on getting a response instead of an exception.
"""
@wraps(get_response)
def inner(request):
try:
response = get_response(request)…
except Exception as exc:
response = response_for_exception(request, exc)
return response
return inner
Variable | Value |
---|---|
exc | DoesNotExist('Forecast matching query does not exist.') |
get_response | <bound method BaseHandler._get_response of <django.core.handlers.wsgi.WSGIHandler object at 0x7ff9d242a450>> |
request | <WSGIRequest: GET '/tunis/gammart/sea_temp/november.html'> |
/home/meteopoisk/www/.venv/lib/python3.7/site-packages/django/core/handlers/base.py
in _get_response
break
if response is None:
wrapped_callback = self.make_view_atomic(callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)
except Exception as e:
response = self.process_exception_by_middleware(e, request)…
# Complain if the view returned None (a common error).
if response is None:
if isinstance(callback, types.FunctionType): # FBV
view_name = callback.__name__
else: # CBV
Variable | Value |
---|---|
callback | <function ResortSeaTemp at 0x7ff9d167ed40> |
callback_args | () |
callback_kwargs | {'country': 'tunis', 'period': 'november', 'resort': 'gammart'} |
middleware_method | <bound method Resorts.process_view of <conf.middleware.Resorts object at 0x7ff9d243cc10>> |
request | <WSGIRequest: GET '/tunis/gammart/sea_temp/november.html'> |
resolver | <URLResolver 'conf.urls' (None:None) '^/'> |
resolver_match | ResolverMatch(func=geo.views.ResortSeaTemp, args=(), kwargs={'country': 'tunis', 'resort': 'gammart', 'period': 'november'}, url_name=resort-sea-month, app_names=[], namespaces=[], route=^(?P<country>[\w-]+)/(?P<resort>[\w-]+)/sea_temp/(?P<period>january|february|march|april|may|june|july|august|september|october|november|december|winter|spring|summer|autumn)\.html$) |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7ff9d242a450> |
wrapped_callback | <function ResortSeaTemp at 0x7ff9d167ed40> |
/home/meteopoisk/www/.venv/lib/python3.7/site-packages/django/core/handlers/base.py
in _get_response
response = middleware_method(request, callback, callback_args, callback_kwargs)
if response:
break
if response is None:
wrapped_callback = self.make_view_atomic(callback)
try:
response = wrapped_callback(request, *callback_args, **callback_kwargs)…
except Exception as e:
response = self.process_exception_by_middleware(e, request)
# Complain if the view returned None (a common error).
if response is None:
if isinstance(callback, types.FunctionType): # FBV
Variable | Value |
---|---|
callback | <function ResortSeaTemp at 0x7ff9d167ed40> |
callback_args | () |
callback_kwargs | {'country': 'tunis', 'period': 'november', 'resort': 'gammart'} |
middleware_method | <bound method Resorts.process_view of <conf.middleware.Resorts object at 0x7ff9d243cc10>> |
request | <WSGIRequest: GET '/tunis/gammart/sea_temp/november.html'> |
resolver | <URLResolver 'conf.urls' (None:None) '^/'> |
resolver_match | ResolverMatch(func=geo.views.ResortSeaTemp, args=(), kwargs={'country': 'tunis', 'resort': 'gammart', 'period': 'november'}, url_name=resort-sea-month, app_names=[], namespaces=[], route=^(?P<country>[\w-]+)/(?P<resort>[\w-]+)/sea_temp/(?P<period>january|february|march|april|may|june|july|august|september|october|november|december|winter|spring|summer|autumn)\.html$) |
response | None |
self | <django.core.handlers.wsgi.WSGIHandler object at 0x7ff9d242a450> |
wrapped_callback | <function ResortSeaTemp at 0x7ff9d167ed40> |
/home/meteopoisk/www/.venv/lib/python3.7/site-packages/django/views/generic/base.py
in view
self.head = self.get
self.setup(request, *args, **kwargs)
if not hasattr(self, 'request'):
raise AttributeError(
"%s instance has no 'request' attribute. Did you override "
"setup() and forget to call super()?" % cls.__name__
)
return self.dispatch(request, *args, **kwargs)…
view.view_class = cls
view.view_initkwargs = initkwargs
# take name and docstring from class
update_wrapper(view, cls, updated=())
Variable | Value |
---|---|
args | () |
cls | <class 'geo.views.ResortSeaTemp'> |
initkwargs | {} |
kwargs | {'country': 'tunis', 'period': 'november', 'resort': 'gammart'} |
request | <WSGIRequest: GET '/tunis/gammart/sea_temp/november.html'> |
self | <geo.views.ResortSeaTemp object at 0x7ff9cf310090> |
/home/meteopoisk/www/project/geo/views.py
in dispatch
class StatView(ResortsView):
slug_url_kwarg = 'resort'
# @method_decorator(cache_page(60))
def dispatch(self, request, *args, **kwargs):
return super(StatView, self).dispatch(request, *args, **kwargs)…
def get_stat_years(self, dt_loc_end, month_number):
end_year = dt_loc_end.year
if month_number >= dt_loc_end.month:
end_year -= 1
Variable | Value |
---|---|
__class__ | <class 'geo.views.StatView'> |
args | () |
kwargs | {'country': 'tunis', 'period': 'november', 'resort': 'gammart'} |
request | <WSGIRequest: GET '/tunis/gammart/sea_temp/november.html'> |
self | <geo.views.ResortSeaTemp object at 0x7ff9cf310090> |
/home/meteopoisk/www/.venv/lib/python3.7/site-packages/django/views/generic/base.py
in dispatch
# Try to dispatch to the right method; if a method doesn't exist,
# defer to the error handler. Also defer to the error handler if the
# request method isn't on the approved list.
if request.method.lower() in self.http_method_names:
handler = getattr(self, request.method.lower(), self.http_method_not_allowed)
else:
handler = self.http_method_not_allowed
return handler(request, *args, **kwargs)…
def http_method_not_allowed(self, request, *args, **kwargs):
logger.warning(
'Method Not Allowed (%s): %s', request.method, request.path,
extra={'status_code': 405, 'request': request}
)
Variable | Value |
---|---|
args | () |
handler | <bound method BaseDetailView.get of <geo.views.ResortSeaTemp object at 0x7ff9cf310090>> |
kwargs | {'country': 'tunis', 'period': 'november', 'resort': 'gammart'} |
request | <WSGIRequest: GET '/tunis/gammart/sea_temp/november.html'> |
self | <geo.views.ResortSeaTemp object at 0x7ff9cf310090> |
/home/meteopoisk/www/.venv/lib/python3.7/site-packages/django/views/generic/detail.py
in get
return super().get_context_data(**context)
class BaseDetailView(SingleObjectMixin, View):
"""A base view for displaying a single object."""
def get(self, request, *args, **kwargs):
self.object = self.get_object()
context = self.get_context_data(object=self.object)…
return self.render_to_response(context)
class SingleObjectTemplateResponseMixin(TemplateResponseMixin):
template_name_field = None
template_name_suffix = '_detail'
Variable | Value |
---|---|
args | () |
kwargs | {'country': 'tunis', 'period': 'november', 'resort': 'gammart'} |
request | <WSGIRequest: GET '/tunis/gammart/sea_temp/november.html'> |
self | <geo.views.ResortSeaTemp object at 0x7ff9cf310090> |
/home/meteopoisk/www/project/geo/views.py
in get_context_data
context['month_number'] = month_number
context['stat_years'] = stat_years
context['stats_m'] = context['stats'][month_number - 1]
context['Temps'] = Temps
if when:
context['Temps_sea'] = Temps_sea
sea_temp = Forecast.objects.get(resort=self.object,
dt__gte=dt_curr, dt__lt=dt_curr + timedelta(hours=settings.FCAST_TIME_STEP)).seaTemp_get…
context['months'] = settings.geo_resort.MONTHS_W_LOC
context['when'] = when
context['country'] = self.country
fcasts = self.get_seatemps(period=period)
context['fcasts'] = fcasts
Variable | Value |
---|---|
Temps | defaultdict(<class 'dict'>, {'seaTemp': {2018: [[1, 21.3], [2, 21.2], [3, 21.1], [4, 21.1], [5, 21.1], [6, 21.0], [7, 20.9], [8, 20.8], [9, 20.8], [10, 20.7], [11, 20.6], [12, 20.5], [13, 20.6], [14, 20.6], [15, 20.5], [16, 20.3], [17, 20.2], [18, 20.1], [19, 20.0], [20, 19.9], [21, 19.9], [22, 19.5], [23, 19.4], [24, 19.8], [25, 19.6], [26, 19.5], [27, 19.2], [28, 19.1], [29, 18.9], [30, 18.9]], 2019: [[1, 22.6], [2, 22.6], [3, 22.6], [4, 22.6], [5, 0], [6, 22.2], [7, 22.0], [8, 22.0], [9, 22.0], [10, 21.4], [11, 21.4], [12, 21.5], [13, 21.5], [14, 21.5], [15, 0], [16, 21.2], [17, 20.5], [18, 20.5], [19, 20.5], [20, 0], [21, 0], [22, 0], [23, 0], [24, 19.6], [25, 19.2], [26, 19.2], [27, 19.0], [28, 19.0], [29, 18.9], [30, 18.8]]}}) |
Temps_sea | defaultdict(<class 'list'>, {2018: [[9, 26.2], [10, 23.4], [11, 20.2], [12, 17.2]], 2019: [[1, 15.3], [2, 14.3], [3, 14.9], [4, 15.7], [5, 17.8], [6, 21.7], [7, 26.2], [8, 27.3], [10, 23.8], [11, 20.9], [12, 17.5]], 2020: [[1, 15.4], [2, 15.2]]}) |
__class__ | <class 'geo.views.ResortSeaTemp'> |
avg_temps_2m | ({'cloudy_days_num': 8, 'dayTemp': 17.2, 'daylight_len': '11.4 - 12.6', 'dt_start': datetime.date(1, 3, 1), 'month': 3, 'nightTemp': 10.8, 'rainfall': 38.8, 'rainy_days_num': 5, 'seaTemp': 14.7, 'sun_daily_hours_avg': 8.3, 'sunny_days_num': 18, 'wind_speed': 5.6}, {'cloudy_days_num': 10, 'dayTemp': 14.9, 'daylight_len': '10.4 - 11.3', 'dt_start': datetime.date(1, 2, 1), 'month': 2, 'nightTemp': 9.5, 'rainfall': 38.0, 'rainy_days_num': 6, 'seaTemp': 14.5, 'sun_daily_hours_avg': 6.8, 'sunny_days_num': 12, 'wind_speed': 5.5}) |
context | {'Temps': defaultdict(<class 'dict'>, {'seaTemp': {2018: [[1, 21.3], [2, 21.2], [3, 21.1], [4, 21.1], [5, 21.1], [6, 21.0], [7, 20.9], [8, 20.8], [9, 20.8], [10, 20.7], [11, 20.6], [12, 20.5], [13, 20.6], [14, 20.6], [15, 20.5], [16, 20.3], [17, 20.2], [18, 20.1], [19, 20.0], [20, 19.9], [21, 19.9], [22, 19.5], [23, 19.4], [24, 19.8], [25, 19.6], [26, 19.5], [27, 19.2], [28, 19.1], [29, 18.9], [30, 18.9]], 2019: [[1, 22.6], [2, 22.6], [3, 22.6], [4, 22.6], [5, 0], [6, 22.2], [7, 22.0], [8, 22.0], [9, 22.0], [10, 21.4], [11, 21.4], [12, 21.5], [13, 21.5], [14, 21.5], [15, 0], [16, 21.2], [17, 20.5], [18, 20.5], [19, 20.5], [20, 0], [21, 0], [22, 0], [23, 0], [24, 19.6], [25, 19.2], [26, 19.2], [27, 19.0], [28, 19.0], [29, 18.9], [30, 18.8]]}}), 'Temps_sea': defaultdict(<class 'list'>, {2018: [[9, 26.2], [10, 23.4], [11, 20.2], [12, 17.2]], 2019: [[1, 15.3], [2, 14.3], [3, 14.9], [4, 15.7], [5, 17.8], [6, 21.7], [7, 26.2], [8, 27.3], [10, 23.8], [11, 20.9], [12, 17.5]], 2020: [[1, 15.4], [2, 15.2]]}), 'month': 'Ноябрь', 'month_number': 11, 'object': <Resort: Гамм… <trimmed 9535 bytes string> |
data | <QuerySet [{'dt': datetime.datetime(2018, 10, 31, 23, 0, tzinfo=<UTC>), 'seaTemp': 21.3, 'hour': 0, 'day': 1, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 1, 23, 0, tzinfo=<UTC>), 'seaTemp': 21.2, 'hour': 0, 'day': 2, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 2, 23, 0, tzinfo=<UTC>), 'seaTemp': 21.1, 'hour': 0, 'day': 3, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 3, 23, 0, tzinfo=<UTC>), 'seaTemp': 21.1, 'hour': 0, 'day': 4, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 4, 23, 0, tzinfo=<UTC>), 'seaTemp': 21.1, 'hour': 0, 'day': 5, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 5, 23, 0, tzinfo=<UTC>), 'seaTemp': 21.0, 'hour': 0, 'day': 6, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 6, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.9, 'hour': 0, 'day': 7, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 7, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.8, 'hour': 0, 'day': 8, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 8, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.8, 'hour': 0, 'day': 9, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 9, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.7, 'hour': 0, 'day': 10, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 10, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.6, 'hour': 0, 'day': 11, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 11, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.5, 'hour': 0, 'day': 12, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 12, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.6, 'hour': 0, 'day': 13, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 13, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.6, 'hour': 0, 'day': 14, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 14, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.5, 'hour': 0, 'day': 15, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 15, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.3, 'hour': 0, 'day': 16, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 16, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.2, 'hour': 0, 'day': 17, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 17, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.1, 'hour': 0, 'day': 18, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 18, 23, 0, tzinfo=<UTC>), 'seaTemp': 20.0, 'hour': 0, 'day': 19, 'month': 11, 'year': 2018}, {'dt': datetime.datetime(2018, 11, 19, 23, 0, tzinfo=<UTC>), 'seaTemp': 19.9, 'hour': 0, 'day': 20, 'month': 11, 'year': 2018}, '...(remaining elements truncated)...']> |
data_sea | <QuerySet [{'m': 9, 'y': 2018, 'sea_temp_avg': 26.1777778201633}, {'m': 10, 'y': 2018, 'sea_temp_avg': 23.4483870229413}, {'m': 11, 'y': 2018, 'sea_temp_avg': 20.2366666793823}, {'m': 12, 'y': 2018, 'sea_temp_avg': 17.2193548756261}, {'m': 1, 'y': 2019, 'sea_temp_avg': 15.280645216665}, {'m': 2, 'y': 2019, 'sea_temp_avg': 14.2928571019854}, {'m': 3, 'y': 2019, 'sea_temp_avg': 14.8903225929506}, {'m': 4, 'y': 2019, 'sea_temp_avg': 15.6833334604899}, {'m': 5, 'y': 2019, 'sea_temp_avg': 17.7677417262908}, {'m': 6, 'y': 2019, 'sea_temp_avg': 21.7233333587646}, {'m': 7, 'y': 2019, 'sea_temp_avg': 26.1967740827991}, {'m': 8, 'y': 2019, 'sea_temp_avg': 27.3166669209798}, {'m': 10, 'y': 2019, 'sea_temp_avg': 23.799999823937}, {'m': 11, 'y': 2019, 'sea_temp_avg': 20.9291667938232}, {'m': 12, 'y': 2019, 'sea_temp_avg': 17.5483872813563}, {'m': 1, 'y': 2020, 'sea_temp_avg': 15.3666666666667}, {'m': 2, 'y': 2020, 'sea_temp_avg': 15.1769230182354}]> |
dt | datetime.datetime(2024, 11, 1, 0, 0) |
dt_curr | datetime.datetime(2024, 3, 29, 15, 54, 46, 31201, tzinfo=<UTC>) |
dt_next_month | datetime.datetime(2024, 12, 1, 0, 0) |
dtstr | '2024-11-1' |
fcast | {'day': 30, 'dt': datetime.datetime(2019, 11, 29, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 18.8, 'year': 2019} |
fcast_stat | [{'day': 1, 'dt': datetime.datetime(2019, 10, 31, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 22.6, 'year': 2019}, {'day': 2, 'dt': datetime.datetime(2019, 11, 1, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 22.6, 'year': 2019}, {'day': 3, 'dt': datetime.datetime(2019, 11, 2, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 22.6, 'year': 2019}, {'day': 4, 'dt': datetime.datetime(2019, 11, 3, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 22.6, 'year': 2019}, {'day': 5, 'dt': datetime.datetime(2019, 11, 4, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': None, 'year': 2019}, {'day': 6, 'dt': datetime.datetime(2019, 11, 5, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 22.2, 'year': 2019}, {'day': 7, 'dt': datetime.datetime(2019, 11, 6, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 22.0, 'year': 2019}, {'day': 8, 'dt': datetime.datetime(2019, 11, 7, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 22.0, 'year': 2019}, {'day': 9, 'dt': datetime.datetime(2019, 11, 8, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 22.0, 'year': 2019}, {'day': 10, 'dt': datetime.datetime(2019, 11, 9, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 21.4, 'year': 2019}, {'day': 11, 'dt': datetime.datetime(2019, 11, 10, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 21.4, 'year': 2019}, {'day': 12, 'dt': datetime.datetime(2019, 11, 11, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 21.5, 'year': 2019}, {'day': 13, 'dt': datetime.datetime(2019, 11, 12, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 21.5, 'year': 2019}, {'day': 14, 'dt': datetime.datetime(2019, 11, 13, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 21.5, 'year': 2019}, {'day': 15, 'dt': datetime.datetime(2019, 11, 14, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': None, 'year': 2019}, {'day': 16, 'dt': datetime.datetime(2019, 11, 15, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 21.2, 'year': 2019}, {'day': 17, 'dt': datetime.datetime(2019, 11, 16, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.5, 'year': 2019}, {'day': 18, 'dt': datetime.datetime(2019, 11, 17, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.5, 'year': 2019}, {'day': 19, 'dt': datetime.datetime(2019, 11, 18, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.5, 'year': 2019}, {'day': 20, 'dt': datetime.datetime(2019, 11, 19, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': None, 'year': 2019}, {'day': 21, 'dt': datetime.datetime(2019, 11, 20, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': None, 'year': 2019}, {'day': 22, 'dt': datetime.datetime(2019, 11, 21, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': None, 'year': 2019}, {'day': 23, 'dt': datetime.datetime(2019, 11, 22, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': None, 'year': 2019}, {'day': 24, 'dt': datetime.datetime(2019, 11, 23, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 19.6, 'year': 2019}, {'day': 25, 'dt': datetime.datetime(2019, 11, 24, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 19.2, 'year': 2019}, {'day': 26, 'dt': datetime.datetime(2019, 11, 25, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 19.2, 'year': 2019}, {'day': 27, 'dt': datetime.datetime(2019, 11, 26, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 19.0, 'year': 2019}, {'day': 28, 'dt': datetime.datetime(2019, 11, 27, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 19.0, 'year': 2019}, {'day': 29, 'dt': datetime.datetime(2019, 11, 28, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 18.9, 'year': 2019}, {'day': 30, 'dt': datetime.datetime(2019, 11, 29, 23, 0, tzinfo=<UTC>), 'hour'… <trimmed 4151 bytes string> |
fcast_stats | {2018: [{'day': 1, 'dt': datetime.datetime(2018, 10, 31, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 21.3, 'year': 2018}, {'day': 2, 'dt': datetime.datetime(2018, 11, 1, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 21.2, 'year': 2018}, {'day': 3, 'dt': datetime.datetime(2018, 11, 2, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 21.1, 'year': 2018}, {'day': 4, 'dt': datetime.datetime(2018, 11, 3, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 21.1, 'year': 2018}, {'day': 5, 'dt': datetime.datetime(2018, 11, 4, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 21.1, 'year': 2018}, {'day': 6, 'dt': datetime.datetime(2018, 11, 5, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 21.0, 'year': 2018}, {'day': 7, 'dt': datetime.datetime(2018, 11, 6, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.9, 'year': 2018}, {'day': 8, 'dt': datetime.datetime(2018, 11, 7, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.8, 'year': 2018}, {'day': 9, 'dt': datetime.datetime(2018, 11, 8, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.8, 'year': 2018}, {'day': 10, 'dt': datetime.datetime(2018, 11, 9, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.7, 'year': 2018}, {'day': 11, 'dt': datetime.datetime(2018, 11, 10, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.6, 'year': 2018}, {'day': 12, 'dt': datetime.datetime(2018, 11, 11, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.5, 'year': 2018}, {'day': 13, 'dt': datetime.datetime(2018, 11, 12, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.6, 'year': 2018}, {'day': 14, 'dt': datetime.datetime(2018, 11, 13, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.6, 'year': 2018}, {'day': 15, 'dt': datetime.datetime(2018, 11, 14, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.5, 'year': 2018}, {'day': 16, 'dt': datetime.datetime(2018, 11, 15, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.3, 'year': 2018}, {'day': 17, 'dt': datetime.datetime(2018, 11, 16, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.2, 'year': 2018}, {'day': 18, 'dt': datetime.datetime(2018, 11, 17, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.1, 'year': 2018}, {'day': 19, 'dt': datetime.datetime(2018, 11, 18, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 20.0, 'year': 2018}, {'day': 20, 'dt': datetime.datetime(2018, 11, 19, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 19.9, 'year': 2018}, {'day': 21, 'dt': datetime.datetime(2018, 11, 20, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 19.9, 'year': 2018}, {'day': 22, 'dt': datetime.datetime(2018, 11, 21, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, 'seaTemp': 19.5, 'year': 2018}, {'day': 23, 'dt': datetime.datetime(2018, 11, 22, 23, 0, tzinfo=<UTC>), 'hour': 0, 'month': 11, … <trimmed 10825 bytes string> |
idx | 2019 |
k | 'seaTemp' |
keys | ['seaTemp'] |
kwargs | {'object': <Resort: Гаммарт>} |
loc_curr_month | 3 |
loc_prev_month | 2 |
m | 12 |
month | 'Ноябрь' |
month_en | 'november' |
month_number | 11 |
month_number_next | 12 |
period | 'november' |
r_stat | {'cloudy_days_num': 10, 'dayTemp': 16.4, 'daylight_len': '9.6 - 9.8', 'dt_start': datetime.date(1, 12, 1), 'month': 12, 'nightTemp': 12.1, 'rainfall': 36.5, 'rainy_days_num': 6, 'seaTemp': 17.6, 'sun_daily_hours_avg': 6.4, 'sunny_days_num': 15, 'wind_speed': 4.8} |
sea_temp_bounds | {'max': 15.5, 'min': 14.1} |
sea_years | dict_keys([2018, 2019, 2020]) |
self | <geo.views.ResortSeaTemp object at 0x7ff9cf310090> |
stat | defaultdict(<class 'list'>, {'cloudy_days_num': [[1, 11], [2, 10], [3, 8], [4, 8], [5, 4], [6, 1], [7, 0], [8, 1], [9, 3], [10, 6], [11, 10], [12, 10]], 'dayTemp': [[1, 15.2], [2, 14.9], [3, 17.2], [4, 21.1], [5, 24.9], [6, 29.7], [7, 33.1], [8, 33.8], [9, 30.0], [10, 26.4], [11, 20.8], [12, 16.4]], 'daylight_len': [[1, '9.7 - 10.3'], [2, '10.4 - 11.3'], [3, '11.4 - 12.6'], [4, '12.6 - 13.7'], [5, '13.7 - 14.5'], [6, '14.5 - 14.7'], [7, '14.1 - 14.7'], [8, '13.0 - 14.0'], [9, '11.8 - 13.0'], [10, '10.7 - 11.8'], [11, '9.8 - 10.7'], [12, '9.6 - 9.8']], 'nightTemp': [[1, 10.4], [2, 9.5], [3, 10.8], [4, 13.4], [5, 16.8], [6, 21.6], [7, 25.2], [8, 26.4], [9, 23.9], [10, 20.9], [11, 15.9], [12, 12.1]], 'rainfall': [[1, 29.6], [2, 38.0], [3, 38.8], [4, 17.0], [5, 11.8], [6, 7.6], [7, 2.0], [8, 3.5], [9, 17.1], [10, 40.5], [11, 35.0], [12, 36.5]], 'rainy_days_num': [[1, 5], [2, 6], [3, 5], [4, 1], [5, 0], [6, 0], [7, 0], [8, 0], [9, 0], [10, 2], [11, 4], [12, 6]], 'seaTemp': [[1, 15.5], [2, 14.5], [3, 14.7], [4, 16.3], [5, 18.6], [6, 22.1], [7, 25.2], [8, 26.5], [9, 25.4], [10, 23.5], [11, 20.7], [12, 17.6]], 'sun_daily_hours_avg': [[1, 6.5], [2, 6.8], [3, 8.3], [4, 10.3], [5, 12.1], [6, 13.6], [7, 13.8], [8, 12.9], [9, 10.6], [10, 9.0], [11, 7.0], [12, 6.4]], 'sunny_days_num': [[1, 14], [2, 12], [3, 18], … <trimmed 4918 bytes string> |
stat_years | [2018, 2019] |
stats_sea | {2018: [{'m': 9, 'sea_temp_avg': 26.1777778201633, 'y': 2018}, {'m': 10, 'sea_temp_avg': 23.4483870229413, 'y': 2018}, {'m': 11, 'sea_temp_avg': 20.2366666793823, 'y': 2018}, {'m': 12, 'sea_temp_avg': 17.2193548756261, 'y': 2018}], 2019: [{'m': 1, 'sea_temp_avg': 15.280645216665, 'y': 2019}, {'m': 2, 'sea_temp_avg': 14.2928571019854, 'y': 2019}, {'m': 3, 'sea_temp_avg': 14.8903225929506, 'y': 2019}, {'m': 4, 'sea_temp_avg': 15.6833334604899, 'y': 2019}, {'m': 5, 'sea_temp_avg': 17.7677417262908, 'y': 2019}, {'m': 6, 'sea_temp_avg': 21.7233333587646, 'y': 2019}, {'m': 7, 'sea_temp_avg': 26.1967740827991, 'y': 2019}, {'m': 8, 'sea_temp_avg': 27.3166669209798, 'y': 2019}, {'m': 10, 'sea_temp_avg': 23.799999823937, 'y': 2019}, {'m': 11, 'sea_temp_avg': 20.9291667938232, 'y': 2019}, {'m': 12, 'sea_temp_avg': 17.5483872813563, 'y': 2019}], 2020: [{'m': 1, 'sea_temp_avg': 15.3666666666667, 'y': 2020}, {'m': 2, 'sea_temp_avg': 15.1769230182354, 'y': 2020}]} |
v | 6.4 |
val | 18.8 |
vals | [{'m': 1, 'sea_temp_avg': 15.3666666666667, 'y': 2020}, {'m': 2, 'sea_temp_avg': 15.1769230182354, 'y': 2020}] |
when | 'в ноябре' |
y | 2019 |
/home/meteopoisk/www/.venv/lib/python3.7/site-packages/django/db/models/manager.py
in manager_method
def check(self, **kwargs):
return []
@classmethod
def _get_queryset_methods(cls, queryset_class):
def create_method(name, method):
def manager_method(self, *args, **kwargs):
return getattr(self.get_queryset(), name)(*args, **kwargs)…
manager_method.__name__ = method.__name__
manager_method.__doc__ = method.__doc__
return manager_method
new_methods = {}
for name, method in inspect.getmembers(queryset_class, predicate=inspect.isfunction):
Variable | Value |
---|---|
args | () |
kwargs | {'dt__gte': datetime.datetime(2024, 3, 29, 15, 54, 46, 31201, tzinfo=<UTC>), 'dt__lt': datetime.datetime(2024, 3, 29, 18, 54, 46, 31201, tzinfo=<UTC>), 'resort': <Resort: Гаммарт>} |
name | 'get' |
self | <django.db.models.manager.Manager object at 0x7ff9cf897e10> |
/home/meteopoisk/www/.venv/lib/python3.7/site-packages/django/db/models/query.py
in get
clone = clone.order_by()
num = len(clone)
if num == 1:
return clone._result_cache[0]
if not num:
raise self.model.DoesNotExist(
"%s matching query does not exist." %
self.model._meta.object_name…
)
raise self.model.MultipleObjectsReturned(
"get() returned more than one %s -- it returned %s!" %
(self.model._meta.object_name, num)
)
Variable | Value |
---|---|
args | () |
clone | <QuerySet []> |
kwargs | {'dt__gte': datetime.datetime(2024, 3, 29, 15, 54, 46, 31201, tzinfo=<UTC>), 'dt__lt': datetime.datetime(2024, 3, 29, 18, 54, 46, 31201, tzinfo=<UTC>), 'resort': <Resort: Гаммарт>} |
num | 0 |
self | <QuerySet [<Forecast: Погода на 2018-09-12>, <Forecast: Погода на 2018-09-13>, <Forecast: Погода на 2018-09-13>, <Forecast: Погода на 2018-09-13>, <Forecast: Погода на 2018-09-13>, <Forecast: Погода на 2018-09-13>, <Forecast: Погода на 2018-09-13>, <Forecast: Погода на 2018-09-13>, <Forecast: Погода на 2018-09-13>, <Forecast: Погода на 2018-09-14>, <Forecast: Погода на 2018-09-14>, <Forecast: Погода на 2018-09-14>, <Forecast: Погода на 2018-09-14>, <Forecast: Погода на 2018-09-14>, <Forecast: Погода на 2018-09-14>, <Forecast: Погода на 2018-09-14>, <Forecast: Погода на 2018-09-14>, <Forecast: Погода на 2018-09-15>, <Forecast: Погода на 2018-09-15>, <Forecast: Погода на 2018-09-15>, '...(remaining elements truncated)...']> |
AnonymousUser
No GET data
No POST data
No FILES data
No cookie data
Variable | Value |
---|---|
HTTP_ACCEPT | '*/*' |
HTTP_CONNECTION | 'close' |
HTTP_HOST | 'meteopoisk.ru' |
HTTP_USER_AGENT | 'claudebot' |
HTTP_X_FORWARDED_FOR | '44.223.39.199' |
HTTP_X_FORWARDED_PROTO | 'https' |
HTTP_X_REAL_IP | '44.223.39.199' |
PATH_INFO | '/tunis/gammart/sea_temp/november.html' |
QUERY_STRING | '' |
RAW_URI | '/tunis/gammart/sea_temp/november.html' |
REMOTE_ADDR | '' |
REQUEST_METHOD | 'GET' |
SCRIPT_NAME | '' |
SERVER_NAME | 'meteopoisk.ru' |
SERVER_PORT | '443' |
SERVER_PROTOCOL | 'HTTP/1.0' |
SERVER_SOFTWARE | 'gunicorn/19.9.0' |
gunicorn.socket | <socket.socket fd=9, family=AddressFamily.AF_UNIX, type=SocketKind.SOCK_STREAM, proto=0, laddr=/home/meteopoisk/runs/gunicorn.sock> |
wsgi.errors | <gunicorn.http.wsgi.WSGIErrorsWrapper object at 0x7ff9cc1970d0> |
wsgi.file_wrapper | '' |
wsgi.input | <gunicorn.http.body.Body object at 0x7ff9cc197290> |
wsgi.multiprocess | True |
wsgi.multithread | False |
wsgi.run_once | False |
wsgi.url_scheme | 'https' |
wsgi.version | (1, 0) |
conf.settings.production
Setting | Value |
---|---|
ABSOLUTE_URL_OVERRIDES | {} |
ADMINS | [] |
ADMIN_MEDIA_PREFIX | '/media/admin/' |
AIR_TEMP_MIN | 25 |
ALLOWED_HOSTS | ['.meteopoisk.ru'] |
ALL_SEASONS | {'april': (4, 'Апрель'), 'august': (8, 'Август'), 'autumn': ([9, 10, 11], 'осень'), 'december': (12, 'Декабрь'), 'february': (2, 'Февраль'), 'january': (1, 'Январь'), 'july': (7, 'Июль'), 'june': (6, 'Июнь'), 'march': (3, 'Март'), 'may': (5, 'Май'), 'november': (11, 'Ноябрь'), 'october': (10, 'Октябрь'), 'september': (9, 'Сентябрь'), 'spring': ([3, 4, 5], 'весна'), 'summer': ([6, 7, 8], 'лето'), 'winter': ([1, 2, 12], 'зима')} |
APPEND_SLASH | False |
AUTHENTICATION_BACKENDS | ['django.contrib.auth.backends.ModelBackend'] |
AUTH_PASSWORD_VALIDATORS | '********************' |
AUTH_USER_MODEL | 'auth.User' |
BASE_DIR | '/home/meteopoisk/www/project' |
CACHES | {'default': {'BACKEND': 'django.core.cache.backends.locmem.LocMemCache'}} |
CACHE_MIDDLEWARE_ALIAS | 'default' |
CACHE_MIDDLEWARE_KEY_PREFIX | '********************' |
CACHE_MIDDLEWARE_SECONDS | 600 |
CKEDITOR_UPLOAD_PATH | 'uploads/' |
COUNTRIES_COLUMNS | 3 |
COUNTRIES_TOP_CNT | 16 |
CSRF_COOKIE_AGE | 31449600 |
CSRF_COOKIE_DOMAIN | None |
CSRF_COOKIE_HTTPONLY | False |
CSRF_COOKIE_NAME | 'csrftoken' |
CSRF_COOKIE_PATH | '/' |
CSRF_COOKIE_SAMESITE | 'Lax' |
CSRF_COOKIE_SECURE | False |
CSRF_FAILURE_VIEW | 'django.views.csrf.csrf_failure' |
CSRF_HEADER_NAME | 'HTTP_X_CSRFTOKEN' |
CSRF_TRUSTED_ORIGINS | [] |
CSRF_USE_SESSIONS | False |
DATABASES | {'default': {'ATOMIC_REQUESTS': False, 'AUTOCOMMIT': True, 'CONN_MAX_AGE': 0, 'ENGINE': 'django.contrib.gis.db.backends.postgis', 'HOST': '127.0.0.1', 'NAME': 'meteopoisk', 'OPTIONS': {}, 'PASSWORD': '********************', 'PORT': '5432', 'TEST': {'CHARSET': None, 'COLLATION': None, 'MIRROR': None, 'NAME': None}, 'TIME_ZONE': None, 'USER': 'meteopoisk'}} |
DATABASE_ROUTERS | [] |
DATA_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
DATA_UPLOAD_MAX_NUMBER_FIELDS | 1000 |
DATETIME_FORMAT | 'Y-m-d H:i' |
DATETIME_INPUT_FORMATS | ['%Y-%m-%d %H:%M:%S', '%Y-%m-%d %H:%M:%S.%f', '%Y-%m-%d %H:%M', '%Y-%m-%d', '%m/%d/%Y %H:%M:%S', '%m/%d/%Y %H:%M:%S.%f', '%m/%d/%Y %H:%M', '%m/%d/%Y', '%m/%d/%y %H:%M:%S', '%m/%d/%y %H:%M:%S.%f', '%m/%d/%y %H:%M', '%m/%d/%y'] |
DATE_FORMAT | 'd E, l' |
DATE_INPUT_FORMATS | ['%Y-%m-%d', '%m/%d/%Y', '%m/%d/%y', '%b %d %Y', '%b %d, %Y', '%d %b %Y', '%d %b, %Y', '%B %d %Y', '%B %d, %Y', '%d %B %Y', '%d %B, %Y'] |
DAY_PARTS | {'0': 'Ночью', '12': 'Днем', '18': 'Вечером', '6': 'Утром'} |
DAY_PARTS_FUT | {'12': 'Днем', '21': 'Ночью'} |
DEBUG | True |
DEBUG404 | True |
DEBUG_PROPAGATE_EXCEPTIONS | False |
DECIMAL_SEPARATOR | '.' |
DEFAULT_CHARSET | 'utf-8' |
DEFAULT_CONTENT_TYPE | 'text/html' |
DEFAULT_EXCEPTION_REPORTER_FILTER | 'django.views.debug.SafeExceptionReporterFilter' |
DEFAULT_FILE_STORAGE | 'django.core.files.storage.FileSystemStorage' |
DEFAULT_FROM_EMAIL | 'webmaster@localhost' |
DEFAULT_INDEX_TABLESPACE | '' |
DEFAULT_TABLESPACE | '' |
DISALLOWED_USER_AGENTS | [] |
EMAIL_BACKEND | 'django.core.mail.backends.smtp.EmailBackend' |
EMAIL_HOST | 'localhost' |
EMAIL_HOST_PASSWORD | '********************' |
EMAIL_HOST_USER | '' |
EMAIL_PORT | 25 |
EMAIL_SSL_CERTFILE | None |
EMAIL_SSL_KEYFILE | '********************' |
EMAIL_SUBJECT_PREFIX | '[Django] ' |
EMAIL_TIMEOUT | None |
EMAIL_USE_LOCALTIME | False |
EMAIL_USE_SSL | False |
EMAIL_USE_TLS | False |
FCAST_TIME_STEP | 3 |
FILE_CHARSET | 'utf-8' |
FILE_UPLOAD_DIRECTORY_PERMISSIONS | None |
FILE_UPLOAD_HANDLERS | ['django.core.files.uploadhandler.MemoryFileUploadHandler', 'django.core.files.uploadhandler.TemporaryFileUploadHandler'] |
FILE_UPLOAD_MAX_MEMORY_SIZE | 2621440 |
FILE_UPLOAD_PERMISSIONS | None |
FILE_UPLOAD_TEMP_DIR | None |
FIRST_DAY_OF_WEEK | 1 |
FIXTURE_DIRS | [] |
FORCE_SCRIPT_NAME | None |
FORMAT_MODULE_PATH | None |
FORM_RENDERER | 'django.forms.renderers.DjangoTemplates' |
HOUR_DAY | 12 |
IGNORABLE_404_URLS | [] |
INSTALLED_APPS | ['django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'django.contrib.gis', 'django.contrib.sitemaps', 'django.contrib.sites', 'django.contrib.flatpages', 'sorl.thumbnail', 'geo', 'feedback', 'weather', 'news', 'django_admin_listfilter_dropdown', 'django_pymorphy2', 'search.apps.SearchConfig', 'django.contrib.postgres', 'ckeditor', 'ckeditor_uploader'] |
INTERNAL_IPS | [] |
LANGUAGES | [('ru', 'Русский'), ('en', 'Английский')] |
LANGUAGES_BIDI | ['he', 'ar', 'fa', 'ur'] |
LANGUAGE_CODE | 'ru-ru' |
LANGUAGE_COOKIE_AGE | None |
LANGUAGE_COOKIE_DOMAIN | None |
LANGUAGE_COOKIE_NAME | 'django_language' |
LANGUAGE_COOKIE_PATH | '/' |
LOCALE_PATHS | [] |
LOGGING | {} |
LOGGING_CONFIG | 'logging.config.dictConfig' |
LOGIN_REDIRECT_URL | '/accounts/profile/' |
LOGIN_URL | '/accounts/login/' |
LOGOUT_REDIRECT_URL | None |
MANAGERS | [] |
MEDIA_ROOT | '/home/meteopoisk/www/project/media' |
MEDIA_URL | '/media/' |
MESSAGE_STORAGE | 'django.contrib.messages.storage.fallback.FallbackStorage' |
MIDDLEWARE | ['django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', 'conf.middleware.Resorts', 'django.contrib.flatpages.middleware.FlatpageFallbackMiddleware'] |
MIDDLEWARE_END | [] |
MIDDLEWARE_START | ['django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', 'conf.middleware.Resorts', 'django.contrib.flatpages.middleware.FlatpageFallbackMiddleware'] |
MIGRATION_MODULES | {} |
MONTHS_ORDERED | {'april': 'Апрель', 'august': 'Август', 'december': 'Декабрь', 'february': 'Февраль', 'january': 'Январь', 'july': 'Июль', 'june': 'Июнь', 'march': 'Март', 'may': 'Май', 'november': 'Ноябрь', 'october': 'Октябрь', 'september': 'Сентябрь'} |
MONTHS_W_LOC | {1: ('january', 'Январь'), 2: ('february', 'Февраль'), 3: ('march', 'Март'), 4: ('april', 'Апрель'), 5: ('may', 'Май'), 6: ('june', 'Июнь'), 7: ('july', 'Июль'), 8: ('august', 'Август'), 9: ('september', 'Сентябрь'), 10: ('october', 'Октябрь'), 11: ('november', 'Ноябрь'), 12: ('december', 'Декабрь')} |
MONTH_DAY_FORMAT | 'F j' |
MORPH | <pymorphy2.analyzer.MorphAnalyzer object at 0x7ff9de2e5650> |
NIGHT_DAY_DELTA | 12 |
NUMBER_GROUPING | 3 |
PASSWORD_HASHERS | '********************' |
PASSWORD_RESET_TIMEOUT_DAYS | '********************' |
PERIODS | ['hours', '24hours', 'tomorrow', '3days', '5days', '7days', '10days', '14days', 'weekend'] |
PERIODS_DIC | {'10days': 'на 10 дней', '14days': 'на 14 дней', '24hours': 'на 24 часа', '3days': 'на 3 дня', '5days': 'на 5 дней', '7days': 'на 7 дней', 'hours': 'почасовая', 'tomorrow': 'на завтра', 'weekend': 'на выходные'} |
PERIODS_TR | ['почасовая', 'на 24 часа', 'на завтра', 'на 3 дня', 'на 5 дней', 'на 7 дней', 'на 10 дней', 'на 14 дней', 'на выходные'] |
PREPEND_WWW | False |
RELAX_TOP_CNT | 15 |
RESORTS_COLUMNS | 3 |
RESORTS_ON_INDEX_PAGE | 8 |
ROOT_URLCONF | 'conf.urls' |
SEASONS | {'autumn': ([9, 10, 11], 'осень'), 'spring': ([3, 4, 5], 'весна'), 'summer': ([6, 7, 8], 'лето'), 'winter': ([1, 2, 12], 'зима')} |
SEA_TEMPS_CNT | 25 |
SEA_TEMP_MIN | 20 |
SECRET_KEY | '********************' |
SECURE_BROWSER_XSS_FILTER | False |
SECURE_CONTENT_TYPE_NOSNIFF | False |
SECURE_HSTS_INCLUDE_SUBDOMAINS | False |
SECURE_HSTS_PRELOAD | False |
SECURE_HSTS_SECONDS | 0 |
SECURE_PROXY_SSL_HEADER | None |
SECURE_REDIRECT_EXEMPT | [] |
SECURE_SSL_HOST | None |
SECURE_SSL_REDIRECT | False |
SERVER_EMAIL | 'root@localhost' |
SESSION_CACHE_ALIAS | 'default' |
SESSION_COOKIE_AGE | 1209600 |
SESSION_COOKIE_DOMAIN | None |
SESSION_COOKIE_HTTPONLY | True |
SESSION_COOKIE_NAME | 'sessionid' |
SESSION_COOKIE_PATH | '/' |
SESSION_COOKIE_SAMESITE | 'Lax' |
SESSION_COOKIE_SECURE | False |
SESSION_ENGINE | 'django.contrib.sessions.backends.db' |
SESSION_EXPIRE_AT_BROWSER_CLOSE | False |
SESSION_FILE_PATH | None |
SESSION_SAVE_EVERY_REQUEST | False |
SESSION_SERIALIZER | 'django.contrib.sessions.serializers.JSONSerializer' |
SETTINGS_MODULE | 'conf.settings.production' |
SHORT_DATETIME_FORMAT | 'Y/m/d P' |
SHORT_DATE_FORMAT | 'Y/m/d' |
SHORT_DATE_FORMAT2 | 'd F' |
SIGNING_BACKEND | 'django.core.signing.TimestampSigner' |
SILENCED_SYSTEM_CHECKS | [] |
SITE_ID | 1 |
STATICFILES_DIRS | ['/home/meteopoisk/www/project/feedback/static', '/home/meteopoisk/www/project/geo/static'] |
STATICFILES_FINDERS | ['django.contrib.staticfiles.finders.FileSystemFinder', 'django.contrib.staticfiles.finders.AppDirectoriesFinder'] |
STATICFILES_STORAGE | 'django.contrib.staticfiles.storage.StaticFilesStorage' |
STATIC_ROOT | '/home/meteopoisk/www/project/static' |
STATIC_URL | '/static/' |
STAT_TOP_CNT | 5 |
TEMPLATES | [{'APP_DIRS': True, 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': ['/home/meteopoisk/www/project/templates', '/home/meteopoisk/www/project/geo/templates', '/home/meteopoisk/www/project/feedback/templates', '/home/meteopoisk/www/project/weather/templates'], 'OPTIONS': {'context_processors': ['django.template.context_processors.csrf', 'django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages', 'django.template.context_processors.static', 'django.template.context_processors.media', 'django.template.context_processors.tz']}}] |
TEST_NON_SERIALIZED_APPS | [] |
TEST_RUNNER | 'django.test.runner.DiscoverRunner' |
THOUSAND_SEPARATOR | ',' |
TIME_FORMAT | 'H:i' |
TIME_INPUT_FORMATS | ['%H:%M:%S', '%H:%M:%S.%f', '%H:%M'] |
TIME_ZONE | 'UTC' |
TIME_ZONE_MSK | 'Europe/Moscow' |
USE_I18N | True |
USE_L10N | False |
USE_THOUSAND_SEPARATOR | False |
USE_TZ | True |
USE_X_FORWARDED_HOST | False |
USE_X_FORWARDED_PORT | False |
WSGI_APPLICATION | 'conf.wsgi.application' |
X_FRAME_OPTIONS | 'SAMEORIGIN' |
YEAR_MONTH_FORMAT | 'F Y' |
You're seeing this error because you have DEBUG = True
in your
Django settings file. Change that to False
, and Django will
display a standard page generated by the handler for this status code.