编译环境:pycharm专业版,python3.7.0,Django2.1.7
一. 创建django程序
- 免费版pycharm:输入终端命令django-admin startproject sitename
- 付费版pycharm:创建Django项目
其他常用命令:
二. 项目目录
三. 配置文件
1.配置数据库
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME':'dbname',
'USER': 'root',
'PASSWORD': 'xxx',
'HOST': '',
'PORT': '',
}
}
由于Django内部连接mysql时使用的是mysqldb模块,而python3中还无此模块,所以需要使用pymysql来代替,如下设置放置的与project同名的配置的 init.py文件中
import pymysql
pymysql.install_as_MySQLdb()
2.配置模板路径
TEMPLATE_DIRS = (
os.path.join(BASE_DIR,'templates'),
)
3.配置静态文件路径
STATICFILES_DIRS = (
os.path.join(BASE_DIR,'static'),
)
4.配置路由
- 单一路由对应
url(r'^index$', views.index),
- 基于正则的路由
url(r'^index/(\d*)', views.index),
url(r'^manage/(?P<name>\w*)/(?P<id>\d*)', views.manage),
- 添加额外的参数
url(r'^manage/(?P<name>\w*)', views.manage,{'id':333}),
- 为路由映射设置名称
url(r'^home', views.home, name='h1'),
url(r'^index/(\d*)', views.index, name='h2'),
设置名称之后,可以在不同的地方调用,如:
模板中使用生成URL {% url ‘h2’ 2012 %}
函数中使用生成URL reverse(‘h2’, args=(2012,)) 路径:django.urls.reverse
Model中使用获取URL 自定义get_absolute_url() 方法:
class NewType(models.Model):
caption = models.CharField(max_length=16)
def get_absolute_url(self):
"""
为每个对象生成一个URL
应用:在对象列表中生成查看详细的URL,使用此方法即可!!!
:return:
"""
# return '/%s/%s' % (self._meta.db_table, self.id)
# 或
from django.urls import reverse
return reverse('NewType.Detail', kwargs={'nid': self.id})
获取请求匹配成功的URL信息:request.resolver_match
- 根据app对路由规则进行分类
url(r'^web/',include('web.urls')),
- 命名空间
from django.conf.urls import url,include
urlpatterns = [
url(r'^a/', include('app01.urls', namespace='author-polls')),
url(r'^b/', include('app01.urls', namespace='publisher-polls')),
]
from django.conf.urls import url
from app01 import views
app_name = 'app01'
urlpatterns = [
url(r'^(?P<pk>\d+)/$', views.detail, name='detail')
]
def detail(request, pk):
print(request.resolver_match)
return HttpResponse(pk)
以上定义带命名空间的url之后,使用name生成URL时候,应该如下:
v = reverse('app01:detail', kwargs={'pk':11})
{% url 'app01:detail' pk=12 pp=99 %}
django中的路由系统和其他语言的框架有所不同,在django中每一个请求的url都要有一条路由映射,这样才能将请求交给对一个的view中的函数去处理。其他大部分的web框架则是对一类的url请求做一条路由映射,从而是路由系统变得简洁。