django 路由系统,数据库操作
数据库
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME':'dbname',
'USER': 'root',
'PASSWORD': 'xxx',
'HOST': '',
'PORT': '',
}
}
# 由于Django内部连接MySQL时使用的是MySQLdb模块,而python3中还无此模块,所以需要使用pymysql来代替
# 如下设置放置的与project同名的配置的 __init__.py文件,或settings 中, 目的就是执行一遍pymysql.install......
import pymysql
pymysql.install_as_MySQLdb()
模版及静态文件:
TEMPLATE_DIRS = [
os.path.join(BASE_DIR, 'templates'),
]
STATICFILES_DIRS = (
(os.path.join(BASE_DIR, 'static'),
)
- 单一路由对应:
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() 方法
使用django.urls下的 include方法进行二级路由分配
一级路由:
project同名的urls.py文件内:
from django.urls import path
from django.urls import include
urlpatterns = [
path('blog/', include('blog.urls')),
]
二级路由:
app下创建urls.py
from django.urls import path
from blog import views
urlpatterns = [
path('index/', views.index),
]
name 参数与路由反解:
经常在视图函数中需要拿到前来的路由关系,除了:
request.path_info拿到全路径只为,
还能使用django.urls 下的 reverse(name)函数进行反解url
只需要在urls.py文件中的路由关系映射后面加上name参数,并给一个值,让reverse拿着这个值反解
#urls.py 内
urlpatterns = [
path('article/', views.article, name='article'),
]
#views.py文件内
from django.urls import reverse
def article(request):
url_article = reverse('article')
return render(request, 'article.html', {'url': url_article})
命名空间:
#project.urls.py
from django.conf.urls import url,include
urlpatterns = [
path('a/', include('blog.urls', namespace='author-polls')),
path('b/', include('blog.urls', namespace='publisher-polls')),
]
blog.urls.py
from django.conf.urls import path
from blogimport views
app_name = 'blog'
urlpatterns = [
path('article/<int:pid>/$', views.detail, name='detail')
]
以上定义带命名空间的url之后,使用name生成URL时候,应该如下:
v = reverse('author-polls:detail', kwargs={'pid':11})
{% url 'publisher-polls:detail' pid=12 %}
django 路由系统,数据库操作的更多相关文章
- 【python】-- Django路由系统(网址关系映射)、视图、模板
Django路由系统(网址关系映射).视图.模板 一.路由系统(网址关系映射) 1.单一路由对应: 一个url对应一个视图函数(类) urls.py: url(r'^test', views.test ...
- Django路由系统
django路由系统 简而言之,django的路由系统作用就是使views里面处理数据的函数与请求的url建立映射关系.使请求到来之后,根据urls.py里的关系条目,去查找到与请求对应的处理方法,从 ...
- Django 路由系统
Django 路由系统 基本格式 from django.conf.urls import url urlpatterns = [ url(正则表达式, views视图函数,参数,别名), ] 参数说 ...
- Python学习---Django路由系统【all】
Django URL (路由系统) Django URL (路由系统): URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL模式以及要为该URL模式调用的视图函数之间的映 ...
- 关于Django中的数据库操作API之distinct去重的一个误传
转载自http://www.360doc.com/content/18/0731/18/58287567_774731201.shtml django提供的数据库操作API中的distinct()函数 ...
- Django路由系统-分组命名匹配
Django路由系统 分组命名匹配 在上述基本配置示例中,使用了简单的正则表达式分组匹配来捕获URL中的值并以位置参数的形式传递给视图,例如url(r'^articles/([0-9]{4})/( ...
- Django路由系统-URLconf配置、正则表达式简述
Django路由系统 1.11版本官方文档 URL配置就像是Django项目的目录,它的本质是URL与URL调用的函数之间的映射表,Django会根据URL配置,在遇到一个URL时,就去执行相应的 ...
- Django【第5篇】:Django之ORM数据库操作
django之ORM数据库操作 一.ORM介绍 映射关系: 表名 -------------------->类名 字段-------------------->属性 表记录-------- ...
- django上课笔记1-目录介绍-路由系统-ORM操作
一.Django目录介绍 django-admin startproject mysite # 创建名为mysite的项目 cd mysite # 切换到该目录下 python manage.py s ...
随机推荐
- c/c++链队列
链队列 链队列就是简化了的单链表 nodequeue.h #ifndef __NODEQUEUE__ #define __NODEQUEUE__ #include <stdio.h> #i ...
- Dockfile制作镜像
讲一个简单的案例 @哈希码用来校验,这样子会安全 MAINTANIER可能将会被LABEL代替,仅仅说说明一下镜像信息罢了. 1.首先是我们创建一个镜像 [root@ELK-chaofeng08 ~] ...
- May 28. 2018 Week 22nd Monday
Do one thing at a time, and do well. 一次只做一件事,并且要做到最好. Why is it that about 25% to 50% of people have ...
- May 24. 2018 Week 21st Thursday
Man errs so long as he strives. 失误是进取的代价. It is not important that the man in the arena didn't win, ...
- css点滴2—六种方式实现元素水平居中
本文参考文章<六种方式实现元素水平居中> 元素水平居中的方法,最常见的莫过于给元素一个显式的宽度,然后加上margin的左右值为auto.这种方式给固定宽度的元素设置居中是最方便不过的.但 ...
- fg和bg前后台调度命令
Linux下的fg和bg命令是进程的前后台调度命令,即将指定号码(非进程号)的命令进程放到前台或后台运行.比如一个需要长时间运行的命令,我们就希望把它放入后台,这样就不会阻塞当前的操作:而一些服务型的 ...
- 让ie8支持 placeholder 属性
一. ie8支持 placeholder 属性 /* * ie8支持 placeholder 属性 */ $(function(){ if( !('placeholder' in document. ...
- CAS适用场景
转载:http://www.jb51.net/article/86192.htm 下面小编就为大家带来一篇Java并发编程总结——慎用CAS详解.小编觉得挺不错的, 现在就分享给大家,也给大家做个参考 ...
- HTTP协议中GET和POST的区别(详细描述)
HTTP协议在现代网络通信中被广泛应用,在HTTP 1.0版本中有7种请求方式,在HTTP 1.1版本中有8种请求方式,而这些请求方式中最常用的就是GET和POST,网上关于GET与POST请求方式的 ...
- 转://Oracle undo 自动调优
Oracle 10gr2的后续版本中添加了UNDO信息最短保留时间段自动调优的特性,不再仅仅依据参数UNDO_RETENTION的设定,其调优原则如下:1. 当UNDO TABLESPACE为 fix ...