我在这里已经阅读了很多答案,但没有人回答我的确切问题。
我做了第一部分,民意调查。我开始第2部分,管理员,然而,在runserve之后,当我尝试访问页面时,这是我得到的错误(我的项目名称是john):
Page not found (404)
Request Method: GET
Request URL: http://127.0.0.1:8000/
Using the URLconf defined in john.urls, Django tried these URL patterns, in this order:
^admin/
The current URL, , didn't match any of these.
You're seeing this error because you have DEBUG = True in your Django settings file. ``
我的代码 - urls.py:
from django.conf.urls import patterns, include, url
# Uncomment the next two lines to enable the admin:
from django.contrib import admin
admin.autodiscover()
urlpatterns = patterns('',
# Examples:
# url(r'^$', 'newgrid.views.home', name='home'),
# url(r'^newgrid/', include('newgrid.foo.urls')),
# Uncomment the admin/doc line below to enable admin documentation:
# url(r'^admin/doc/', include('django.contrib.admindocs.urls')),
# Uncomment the next line to enable the admin:
url(r'^admin/', include(admin.site.urls)),
)
Models.py:
from django.db import models
import datetime
from django.utils import timezone
# Create your models here.
from django.db import models
class Poll(models.Model):
question = models.CharField(max_length=200)
pub_date = models.DateTimeField('date published')
def __unicode__(self):
return self.question
def was_published_recently(self):
return self.pub_date >= timezone.now() - datetime.timedelta(days=1)
class Choice(models.Model):
poll = models.ForeignKey(Poll)
choice = models.CharField(max_length=200)
votes = models.IntegerField()
def __unicode__(self):
return self.choice
settings.py:
# Django settings for newgrid project.
DEBUG = True
TEMPLATE_DEBUG = DEBUG
ADMINS = (
# ('Your Name', 'your_email@example.com'),
)
MANAGERS = ADMINS
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.sqlite3', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'.
'NAME': 'C:/john/john/johny.db', # Or path to database file if using sqlite3.
'USER': '', # Not used with sqlite3.
'PASSWORD': '', # Not used with sqlite3.
'HOST': '', # Set to empty string for localhost. Not used with sqlite3.
'PORT': '', # Set to empty string for default. Not used with sqlite3.
}
}
# Local time zone for this installation. Choices can be found here:
# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
# although not all choices may be available on all operating systems.
# In a Windows environment this must be set to your system time zone.
TIME_ZONE = 'America/Chicago'
# Language code for this installation. All choices can be found here:
# http://www.i18nguy.com/unicode/language-identifiers.html
LANGUAGE_CODE = 'en-us'
SITE_ID = 1
# If you set this to False, Django will make some optimizations so as not
# to load the internationalization machinery.
USE_I18N = True
# If you set this to False, Django will not format dates, numbers and
# calendars according to the current locale.
USE_L10N = True
# If you set this to False, Django will not use timezone-aware datetimes.
USE_TZ = True
# Absolute filesystem path to the directory that will hold user-uploaded files.
# Example: "/home/media/media.lawrence.com/media/"
MEDIA_ROOT = ''
# URL that handles the media served from MEDIA_ROOT. Make sure to use a
# trailing slash.
# Examples: "http://media.lawrence.com/media/", "http://example.com/media/"
MEDIA_URL = ''
# Absolute path to the directory static files should be collected to.
# Don't put anything in this directory yourself; store your static files
# in apps' "static/" subdirectories and in STATICFILES_DIRS.
# Example: "/home/media/media.lawrence.com/static/"
STATIC_ROOT = ''
# URL prefix for static files.
# Example: "http://media.lawrence.com/static/"
STATIC_URL = '/static/'
# Additional locations of static files
STATICFILES_DIRS = (
# Put strings here, like "/home/html/static" or "C:/www/django/static".
# Always use forward slashes, even on Windows.
# Don't forget to use absolute paths, not relative paths.
)
# List of finder classes that know how to find static files in
# various locations.
STATICFILES_FINDERS = (
'django.contrib.staticfiles.finders.FileSystemFinder',
'django.contrib.staticfiles.finders.AppDirectoriesFinder',
# 'django.contrib.staticfiles.finders.DefaultStorageFinder',
)
# Make this unique, and don't share it with anybody.
SECRET_KEY = 'cl8%_lzxbct-^ebmpje25%r&5*0=$qmv9gw6i$^arox*kr4$_e'
# List of callables that know how to import templates from various sources.
TEMPLATE_LOADERS = (
'django.template.loaders.filesystem.Loader',
'django.template.loaders.app_directories.Loader',
# 'django.template.loaders.eggs.Loader',
)
MIDDLEWARE_CLASSES = (
'django.middleware.common.CommonMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
# Uncomment the next line for simple clickjacking protection:
# 'django.middleware.clickjacking.XFrameOptionsMiddleware',
)
ROOT_URLCONF = 'newgrid.urls'
# Python dotted path to the WSGI application used by Django's runserver.
WSGI_APPLICATION = 'newgrid.wsgi.application'
TEMPLATE_DIRS = (
# Put strings here, like "/home/html/django_templates" or "C:/www/django/templates".
# Always use forward slashes, even on Windows.
# Don't forget to use absolute paths, not relative paths.
)
INSTALLED_APPS = (
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.sites',
'django.contrib.messages',
'django.contrib.staticfiles',
# Uncomment the next line to enable the admin:
'django.contrib.admin',
# Uncomment the next line to enable admin documentation:
#'django.contrib.admindocs',
'polls'
)
# A sample logging configuration. The only tangible logging
# performed by this configuration is to send an email to
# the site admins on every HTTP 500 error when DEBUG=False.
# See http://docs.djangoproject.com/en/dev/topics/logging for
# more details on how to customize your logging configuration.
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'filters': {
'require_debug_false': {
'()': 'django.utils.log.RequireDebugFalse'
}
},
'handlers': {
'mail_admins': {
'level': 'ERROR',
'filters': ['require_debug_false'],
'class': 'django.utils.log.AdminEmailHandler'
}
},
'loggers': {
'django.request': {
'handlers': ['mail_admins'],
'level': 'ERROR',
'propagate': True,
},
}
}
多数民众赞成。哦,是的,我在WinXP。
答案 0 :(得分:6)
您导航到错误的网址。作为the tutorial says,
现在,打开Web浏览器并转到本地域的
/admin/
- ,例如,http://127.0.0.1:8000/admin/
。您应该看到管理员的登录屏幕:
答案 1 :(得分:3)
在您的网址中,您还没有为根网址定义视图,这就是为什么只有当您将浏览器指向以admin/
开头的网址时,您的应用才能正常工作
取消注释以下行:
# url(r'^$', 'newgrid.views.home', name='home'),
并将'newgrid.views.home'
更改为现有视图,可能会呈现包含一些临时链接的普通模板。
答案 2 :(得分:2)
我知道这是很久以前的问题,但也许人们仍在寻找同样问题的答案,就像我一样。对我来说,我提出的问题是 urls.py我已经改变了。关键是更改PROJECT urls.py,而不是APP urls.py文件。
例如,如果您的PROJECT被称为“mysite”且APP正在“轮询”您想要更改的文件位于此处:
/mysite/urls.py
不是应用版本(位于/polls/urls.py中)。
另外,你可能会犯这样的错误,即将/polls/urls.py更改为新的“命名空间”语法然后,在对/mysite/urls.py进行更改后,忘记更改/ polls / urls.py返回到教程3(https://docs.djangoproject.com/en/1.7/intro/tutorial03/)的“编写更多视图”部分中给出的原始代码
希望这有助于某人。 (这将是我第一次对StackOverflow做出贡献!)答案 3 :(得分:1)
我也完成了本教程,在第3部分遇到了同样错误的问题;我的困惑在于目录结构。
我在我认为教程指定的目录中编写了urls.py文件,但它是~/mysite/urls.py
,而教程实际指定了~/mysite/mysite/urls.py
教程还提示我们创建的文件~mysite/polls/urls.py
位置正确,我应该怀疑这两组指令只列出了内部目录(polls
或{{ 1}})。在遇到这个问题之后我不得不重新阅读教程的第1部分,但后来我终于理解了以下文本:
内部
mysite
目录是项目的实际Python包。
答案 4 :(得分:0)
你应该试试这个声明" url(r' ^民意调查/',包括(' polls.urls')),"在" mysite / mysite / urls.py"中的urlpatterns类下文件,然后你可以看到你想要的东西
答案 5 :(得分:0)
我有同样的问题,现在通过两种方式得到解决方案,通过编辑 [mysite / mysite / urls.py] 中的urls.py或更改 ROOT_URLCONF 如果您已在manage.py存在的路径中编辑urls.py,则在 urls.py 的设置中。