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 ...
随机推荐
- Linux中环境变量中文件执行顺序
Linux 的变量可分为两类:环境变量和本地变量 环境变量:或者称为全局变量,存在于所有的shell 中,在你登陆系统的时候就已经有了相应的系统定义的环境变量了.Linux 的环境变量具有 ...
- 安装Window 10系统------计算机经验
为什么这次安装window10系统呢?不是和window7系统的安装方法一样么?如果你是这样的想的话,是不完全对的,因为window10系统的安装有些繁杂,需要耐心.下面我就准备了官方原版的windo ...
- jQuery设置radio、select、checkbox只读属性后,如何在后台得到数据
1 设置表单的readonly属性 对于radio.select.checkbox来说,readonly属性对这三个标签不起什么作用. 2 设置表单的disabled属性 以radio为例说明. 代码 ...
- March 06th, 2018 Week 10th Tuesday
Hope for the best, but prepare for the worst. 抱最好的愿望,做最坏的打算. To hope for the best and prepare for th ...
- C#基础知识之键盘对应的键值
1.一般的按键禁用 一般的按键禁用只要找出相应的keycode禁用即可.例如:window.event.keyCode==13 //Enter键 其他可以对照一下的keyCode进行选择. 字母和数字 ...
- nginx: worker process is shutting down
正常情况下,nginx进程状态如下: 当修改配置文件,reload之后: PID=17114的wroker有正在处理的连接,等处理结束,该worker就会退出(退出之前,该worker不会处理新的连接 ...
- JSONCkecker(Java语言版本)
// MIT License // // Copyright (c) 2016 Michel Kraemer // Copyright (c) 2005 JSON.org // // Permissi ...
- UVA11925-Generating Permutations(贪心)
Problem UVA11925-Generating Permutations Accept: 214 Submit: 1429Time Limit: 1000 mSec Problem Desc ...
- Md5的生成
1.使用hashlib包(一) import hashlib src = 'anthing' m1 = hash.new() m1.update(src) print (m1.hexdigest()) ...
- P1451 求细胞数量(广搜)
题意:就是0把是所有细胞圈起来了.而被圈起来的是所有数字全部为一个细胞问有多少个这样的细胞.(mmp,我读半天题) 思路:广搜索.就是,0的话就不放入了,不为0的话,就进入队列,然后,再看它的4个方向 ...