一、修改配置

数据库

  1. DATABASES = {
  2. 'default': {
  3. 'ENGINE': 'django.db.backends.mysql',
  4. 'NAME':'dbname',
  5. 'USER': 'root',
  6. 'PASSWORD': 'xxx',
  7. 'HOST': '',
  8. 'PORT': '',
  9. }
  10. }
  11. # 由于Django内部连接MySQL时使用的是MySQLdb模块,而python3中还无此模块,所以需要使用pymysql来代替
  12. # 如下设置放置的与project同名的配置的 __init__.py文件,或settings 中, 目的就是执行一遍pymysql.install......
  13. import pymysql
  14. pymysql.install_as_MySQLdb() 

模版及静态文件:

  1. TEMPLATE_DIRS = [
  2. os.path.join(BASE_DIR, 'templates'),
  3. ]
  4. STATICFILES_DIRS = (
  5. (os.path.join(BASE_DIR, 'static'),
  6. )
二、路由系统

- 单一路由对应:
path('home/', views.index)

  • 内置正则路由:

    path('articles/<int: pid>/', views.article)

    article函数内:

    def article(request, *args, **kwargs):

      #kwargs 中存储了{'pid': 17}

      return render(request, 'aritcle.html')

  • 为路由映射设置名称

    path('home/', views.home, name='home'),

    path('article/int:pid', views.index, name='article'),

    设置名称之后,可以在不同的地方调用,如:

     

    模板中使用生成URL {% url 'home' 2017 %}

    函数中使用生成URL reverse('article', args=(2017,)) from django.urls import reverse

    Model中使用获取URL 自定义get_absolute_url() 方法

2.2 一二级路由分配

使用django.urls下的 include方法进行二级路由分配

一级路由:

project同名的urls.py文件内:

  1. from django.urls import path
  2. from django.urls import include
  3. urlpatterns = [
  4. path('blog/', include('blog.urls')),
  5. ]

二级路由:

app下创建urls.py

  1. from django.urls import path
  2. from blog import views
  3. urlpatterns = [
  4. path('index/', views.index),
  5. ]

name 参数与路由反解:

经常在视图函数中需要拿到前来的路由关系,除了:

request.path_info拿到全路径只为,

还能使用django.urls 下的 reverse(name)函数进行反解url

只需要在urls.py文件中的路由关系映射后面加上name参数,并给一个值,让reverse拿着这个值反解

  1. #urls.py 内
  2. urlpatterns = [
  3. path('article/', views.article, name='article'),
  4. ]
  5. #views.py文件内
  6. from django.urls import reverse
  7. def article(request):
  8. url_article = reverse('article')
  9. return render(request, 'article.html', {'url': url_article})

命名空间:

  1. #project.urls.py
  2. from django.conf.urls import url,include
  3. urlpatterns = [
  4. path('a/', include('blog.urls', namespace='author-polls')),
  5. path('b/', include('blog.urls', namespace='publisher-polls')),
  6. ]
  7. blog.urls.py
  8. from django.conf.urls import path
  9. from blogimport views
  10. app_name = 'blog'
  11. urlpatterns = [
  12. path('article/<int:pid>/$', views.detail, name='detail')
  13. ]
  14. 以上定义带命名空间的url之后,使用name生成URL时候,应该如下:
  15. v = reverse('author-polls:detail', kwargs={'pid':11})
  16. {% url 'publisher-polls:detail' pid=12 %}

django 路由系统,数据库操作的更多相关文章

  1. 【python】-- Django路由系统(网址关系映射)、视图、模板

    Django路由系统(网址关系映射).视图.模板 一.路由系统(网址关系映射) 1.单一路由对应: 一个url对应一个视图函数(类) urls.py: url(r'^test', views.test ...

  2. Django路由系统

    django路由系统 简而言之,django的路由系统作用就是使views里面处理数据的函数与请求的url建立映射关系.使请求到来之后,根据urls.py里的关系条目,去查找到与请求对应的处理方法,从 ...

  3. Django 路由系统

    Django 路由系统 基本格式 from django.conf.urls import url urlpatterns = [ url(正则表达式, views视图函数,参数,别名), ] 参数说 ...

  4. Python学习---Django路由系统【all】

    Django URL (路由系统) Django URL (路由系统): URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL模式以及要为该URL模式调用的视图函数之间的映 ...

  5. 关于Django中的数据库操作API之distinct去重的一个误传

    转载自http://www.360doc.com/content/18/0731/18/58287567_774731201.shtml django提供的数据库操作API中的distinct()函数 ...

  6. Django路由系统-分组命名匹配

    Django路由系统 分组命名匹配 ​ 在上述基本配置示例中,使用了简单的正则表达式分组匹配来捕获URL中的值并以位置参数的形式传递给视图,例如url(r'^articles/([0-9]{4})/( ...

  7. Django路由系统-URLconf配置、正则表达式简述

    Django路由系统 1.11版本官方文档 ​ URL配置就像是Django项目的目录,它的本质是URL与URL调用的函数之间的映射表,Django会根据URL配置,在遇到一个URL时,就去执行相应的 ...

  8. Django【第5篇】:Django之ORM数据库操作

    django之ORM数据库操作 一.ORM介绍 映射关系: 表名 -------------------->类名 字段-------------------->属性 表记录-------- ...

  9. django上课笔记1-目录介绍-路由系统-ORM操作

    一.Django目录介绍 django-admin startproject mysite # 创建名为mysite的项目 cd mysite # 切换到该目录下 python manage.py s ...

随机推荐

  1. Linux学习历程——Centos 7 ps命令基础

    一.ps命令介绍 ps命令是Process Status的缩写,用于查看系统进程状态,ps命令输出值非常多,通常结合管道符使用. 二.实例 1.我们直接输入ps命令,不加任何参数. 可以看到默认输出4 ...

  2. LeetCode算法题-Excel Sheet Column Number(Java实现)

    这是悦乐书的第182次更新,第184篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第41题(顺位题号是171).给定Excel工作表中显示的列标题,返回其对应的列号.例如 ...

  3. ACE侧边栏刷新自动展开之前的选择

    在body下面加上 <script type="text/javascript"> $(document).ready(function(){ var url = do ...

  4. ES5-ES6-ES7_数组的扩展

    Array.prototype.indexOf(value)  得到值在数组中的第一个下标,如果元素不存在返回-1,可以用来判断是否包含指定的元素 var arr = [6,5,4,3,1,7,6]; ...

  5. Fiddler抓包学习

    今天看到一个抓包笔记, 因为是老早抓包的需求, 后期不用就忘了, 换电脑桌面软件图标都没了, 点开看了一下一脸懵逼... 这是啥...  以后有需要在看一遍吧! Fiddler抓包使用教程-扫盲篇 h ...

  6. 如何在C#Asp.Net MVC使用Redis缓存

    为什么要在Asp.Net MVC项目中使用Redis缓存呢?系统是按照高负载高并发来设计的,这就涉及服务器集群带来的问题,Session存储验证码或登录信息,在系统登录的时候,可能展示登录界面和存储验 ...

  7. Python:Day48 Jquery

    引用方式: <script src="jquery-3.3.1.js"></script> jQuery就是一个jQuery对象,可以简写成$ 基本语法:$ ...

  8. metamask的使用

    Metamask 我是在火狐浏览器安装它的,所以一开始安装了Firefox:http://www.firefox.com.cn/ 然后是下载metamask,它的官方网站是https://metama ...

  9. docker 3 docker安装

    centos docker安装 docker支持以下centos版本: centos 7 (64-bit) centos 6.5 (64-bit)或更高的版本 前提条件 目前,centos仅发行版中的 ...

  10. 初学Python——文件操作第二篇

    前言:为什么需要第二篇文件操作?因为第一篇的知识根本不足以支撑基本的需求.下面来一一分析. 一.Python文件操作的特点 首先来类比一下,作为高级编程语言的始祖,C语言如何对文件进行操作? 字符(串 ...