一、数据库表中字段的增删改查,二、路由基础.三、有名无名分组.四、多app共存的路由分配.五、多app共存时模板冲突问题.六、创建app流程.七、路由分发.八、路由别名,九、名称空间.十、反向解析.十一、2.x新特性.十二、自定义转换器

一、数据库表中字段的增删改查

‘‘‘
直接在modules中对字段进行增删改查
然后在tools下点击Run manage.py Task执行makemigrations和migrate
注意在执行字段的删除过程中需不需要对数据进行备份
‘‘‘

二、路由基础

‘‘‘
# url中含有四个参数
# url(regex, view, kwargs=None, name=None)
# 正则路径  视图函数地址  默认关键字参数(了解)  路由别名

# r‘index‘ 只要请求中含有index都可以匹配成功
url(r‘index‘, views.index)

#r‘^index‘ 只要开头是index都可以匹配成功
url(r‘^index‘, views.index)

# r‘^index$‘ 只能匹配index,不能匹配index/
url(r‘^index$‘, views.index)

# r‘^index/$‘ 不仅能匹配index/,还能匹配index(匹配index时先拿index匹配,如果失败,会自动添加/再次匹配)
url(r‘^index/$‘, views.index)

#含有关键字参数,视图函数必须接受这个参数,并且名字必须与关键词参数的key名字相同
url(r‘^testkw/$‘, views.testkw, {‘num‘: 88888})  # def testkw(request, num):

# 路由匹配如何关闭默认添加/
①在sttings.py中将中间件的 ‘django.middleware.common.CommonMiddleware‘ 这行代码注掉
②在settings.py下添加 APPEND_SLASH = False
‘‘‘

三、有名无名分组

‘‘‘
正则
import re
res = re.search(‘/index/(\d+)/(\d+)‘, ‘/index/123/456‘)
print(res.group(1)) #123
print(res.group(2)) #456

#从左往右第一个左括号就是第一个分组
res = re.search(‘(/index/(\d+)/(\d+))‘, ‘/index/123/456‘)
print(res.group(1)) #/index/123/456
print(res.group(2)) #123
print(res.group(3)) #456

#有名分组和无名分组,有名分组可以由名字获得也可以由编号获得
res = re.search(‘/index/(?P<num>\d+)/(\d+)‘, ‘/index/123/456‘)
print(res.group(1)) #123
print(res.group(2)) #456
print(res.group(‘num‘)) #123

‘‘‘
‘‘‘
# 无名分组:/testnoname/10/
url(r‘^testnoname/(\d+)/$‘, views.testnoname)
# def testnoname(request, var)  # var=10 必须要设置一个参数接受10这个值,这个参数命名随意

# 有名分组:/testname/10/1/
url(r‘^testname/(?P<num>\d+)/(?P<page>\d+)/$‘, views.testname)
# def testname(request, page, num)  # page=1 num=10 参数必须与有名分组的名字一致且无先后顺序

# 注:无名分组与有名分组不能混用
‘‘‘

四、多app共存的路由分配

‘‘‘
# 模块导入过程中从上而下进行导入,如果名字相同只有最后一个起作用
# 在主路由中要配置多个app,在urls.py中导入视图函数模块名字相同,我们需要要对视图函数调用起别名
from app01 import views as app01_views
from app02 import views as app02_views

 url(r‘^app01/test_page/$‘, app01_views.test_page),
 url(r‘^app02/test_page/$‘, app02_views.test_page),
‘‘‘

五、多app共存时模板冲突问题

‘‘‘
同名的模板的查找顺序是根据settings.py中 INSTALLED_APPS 的配置顺序从上而下进行查找的

如何解决多app共存时模板冲突问题?
方法1:在对应应用下建立自己的templates,再在templates下建立与应用名同名的文件夹,模板文件放在应用名同名的文件夹下 (实际开发中运用少,不要用)
方法2:在项目根目录下的templates中建立每一个应用同名的文件夹,每个应用的模板文件放在自己应用名文件夹下

使用:render(request, ‘app_name/test.html‘)
‘‘‘

六、创建app流程

‘‘‘
1. python3 manage.py startapp app_name
2. 去settings中配置INSTALLED_APPS, 添加记录:‘app_name.apps.App_nameConfig‘
# 注:app配置的顺序决定了(共同资源冲突下的)查找顺序
‘‘‘

七、路由分发

‘‘‘
# 分担总路由的代码压力, 将每个app的自身路由配置交给app自己的ulrs.py来管理(分文件管理路由)

1.在每一个应用中建立自身的urls.py文件,语法同主路由
2.在主路由进行分发
#url(r‘^blog/‘, include(‘blog.urls‘))

from django.conf.urls import include
urlpatterns = [
    url(r‘^app01/‘, include(‘app01.urls‘)),
    url(r‘^app02/‘, include(‘app02.urls‘)),
]
# 注:主路由分发一定不能使用$正则语法标识结束 (错误eg: ^app01/$)
‘‘‘

八、路由别名

‘‘‘
1.有些路由会被大量访问(直接访问、间接访问)
2.这些路由可能后期还会发生变化
3.可以给路由设置别名
url(r‘^delete_flag_test/(\d+)/$‘, views.delete_flag, name=‘delete_flag_test‘)

前端通过别名访问,在有名和无名分组下使用url别名进行传参的方式一致
<a href="{% url ‘路由别名‘ ‘传入有名无名分组所需参数‘ %}"></a>
‘‘‘

九、名称空间

‘‘‘
如果没有名称空间,有同名的请求时会从上而下进行解析,都会执行app02下的test

名称空间的设置:
主路由:
from django.conf.urls import include
urlpatterns = [
    url(r‘^app01/‘, include(‘app01.urls‘, namespace=‘app01‘)),
    url(r‘^app02/‘, include(‘app02.urls‘, namespace=‘app02‘)),
]

app01应用下路由
from django.conf.urls import url
from app01 import views
urlpatterns = [
    url(r‘^test/‘, views.test, name=‘test‘)
]

app02应用下路由
from django.conf.urls import url
from app02 import views
urlpatterns = [
    url(r‘^test/‘, views.test, name=‘test‘)
]

前端页面反向解析: {% url ‘名称空间名:路由别名‘ %}
{% url ‘app01:test‘ %} | {% url ‘app02:test‘ %}

视图函数reverse方法:url = reverse(‘app01:test‘) | url = reverse(‘app02:test‘)
‘‘‘

十、反向解析

‘‘‘
反向解析:通过路由别名获取真实的路由路径,当真实路径发生改变时,通过别名解析出真实路径的代码不需要改变

from django.shortcuts import reverse
在视图函数中通过reverse方法反向解析出真实的路径

# 1.不带分组:url(r‘可能会变的真实路由‘, 视图函数, name=‘路由别名‘)
url = reverse(‘路由别名‘)

# 2.无名分组:url(r‘可能会变的真实路由(带无名分组)‘, 视图函数, name=‘路由别名‘)
url = reverse(‘路由别名‘, args=(给无名分组赋值))  #args后面跟是一个元组

# 3.有名分组:url(r‘可能会变的真实路由(带有名分组)‘, 视图函数, name=‘路由别名‘)
url = reverse(‘路由别名‘, kwargs={给有名分组赋值,key就是有名分组名})
‘‘‘

十一、2.x新特性

‘‘‘
from django.urls import path, re_path
# 向下兼容,可以使用url,但是不建议使用url, 而是使用与url相同的re_path
from django.conf.urls import url
urlpatterns = [
    path(‘index/‘, views.index),
    # page/<int:msg>/   page/(?P<msg>(\d+))   # 访问/page/123/
    # path(‘page/<int:msg>/‘, views.page),
    # path(‘page/<str:msg>/‘, views.page),
    # path(‘page/<path:msg>/‘, views.page),
    # path(‘page/<slug:msg>/‘, views.page),
    path(‘page/<uuid:msg>/‘, views.page),
]

# 1. 2.x版本re_path的使用方式同1.x版本url
# 2. path写的是绝对字符串,请求地址必须与路由地址完全匹配,后面斜杠省略会自动添加
# 3. path拥有五个转换器:
    -- str:匹配除路径分隔符(/)外的字符串,默认
    -- int:匹配自然数
    -- slug:匹配字母、数字、横杠及下划线组成的字符串
    -- uuid:匹配uuid形式的数据  uuid是一个算法,每次执行都不一样
    -- path:匹配任何字符串,包括路径分隔符(/) (不能用?)

‘‘‘

十二、自定义转换器

‘‘‘
# 原因:自定义正则匹配目标路径

在应用里面建一个conventer.py文件,在下面定义一个如下class
语法:
1.自定义类
# 匹配11位的185电话
class CVT185phone:
    # 正向匹配过程
    regex = ‘185\d{8}‘
    def to_python(self, value):
        return int(value)
    # 反向解析过程
    def to_url(self, value):
        return ‘%11d‘ % value

# 在主路由中
from django.urls import register_converter
from 所在路径 import CVT185phone
register_converter(CVT185phone, ‘phone185‘)

path(‘page/<phone185:msg>/‘, views.page, name="pages")
‘‘‘

原文地址:https://www.cnblogs.com/lizeqian1994/p/10468782.html

时间: 2024-10-12 15:12:29

一、数据库表中字段的增删改查,二、路由基础.三、有名无名分组.四、多app共存的路由分配.五、多app共存时模板冲突问题.六、创建app流程.七、路由分发.八、路由别名,九、名称空间.十、反向解析.十一、2.x新特性.十二、自定义转换器的相关文章

mysql--对行(表中数据)的增删改查

一.插入数据(增加)insert 1.插入数据(顺序插入) 语法一: INSERT INTO 表名(字段1,字段2,字段3-字段n) VALUES(值1,值2,值3-值n); #指定字段来插入数据,插入的值要和你前面的字段相匹配 语法二: INSERT INTO 表名 VALUES (值1,值2,值3-值n); #不指定字段的话,就按照默认的几个字段来插入数据 2.指定字段插入数据 语法: INSERT INTO 表名(字段1,字段2,字段3-) VALUES (值1,值2,值3-); 3.插入

表,字段的增删改查

用SQL语句添加删除修改字段 1.增加字段 alter table docdsp add dspcode char(200) 2.删除字段 ALTER TABLE table_NAME DROP COLUMN column_NAME 3.修改字段类型 ALTER TABLE table_name ALTER COLUMN column_name new_data_type 4.修改表字段 alter table test rename column aa to bb; 5.修改表名 alter

Django项目的创建与介绍.应用的创建与介绍.启动项目.pycharm创建启动项目.生命周期.三件套.静态文件.请求及数据.配置Mysql完成数据迁移.单表ORM记录的增删改查

一.Django项目的创建与介绍 ''' 安装Django #在cmd中输入pip3 #出现这个错误Fatal error in launcher: Unable to create process using '"' #可以直接用 python3 -m pip 代替 pip3 #这个问题是pip3 版本过低直接在cmd中执行 python3 -m pip install --upgrade pip 更新pip3 # 在指定解释器环境下安装django 1.11.9 # 在真实python3环境

yii中数据的"增删改查"相关工作!(此文比较乱,需细看)

使用findByPk()根据数据表主键查询的是对象,不需要使用foreach()循环出来 但是使用findall()和find()查询的是对象类型的数组需要使用foreach()循环出来 ======================================= public function getMinLimit () { $sql = "..."; $result = yii::app()->db->createCommand($sql); $query = $r

Android通讯录数据库介绍与基本操作(增删改查)

Android通讯录数据库介绍与基本操作(增删改查) 2014年2月21日 Android通讯录管理总结 这几天导师安排我一个任务就是研究一下Android通讯录获取联系人.通话记录.短信的方法,还有看看不同Android版本之间的异同是否能做到兼容之类的事情.Android通讯录这一块,我个人感觉是挺乱的,网上一堆关于查询本地数据库获取联系人的方法,但似乎都没有仔细说明数据有哪些重要的表,它们之间有什么联系.下面是本人查询资料总结的一下知识点,方便童鞋们以后用到. http://xys2891

Django静态文件配置、request方法、ORM简介、字段的增删改查

app的创建注意事项: 在Django新创建的app要在seetings.py中添加注册,才会生效 创建app:django-adminapp an startapp app名称 或者 python3 mansge.py startpp名称 手动创建的app不会自带存放html的templates文件夹,需要手动创建 Django静态文件配置 对于前端已经写好了的文件,我们只是拿过来使用,那么这些文件都可以称之为"静态文件"; 静态文件可以是:boostrap一类的前端框架,已经写好了

关于MySql中数据库、表的操作以及增删改查等一些SQL语句注意事项

(1)怎么在cmd中复制粘贴内容? 参考:http://jingyan.baidu.com/article/93f9803fd3a4dde0e46f55f5.html (2)怎么打开进入和退出数据库? --其中-h是主机名,可以写IP地址127.0.0.1,回车后,提示输入密码即可. mysql -h localhost -u root -p --退出数据库是exit或者quit或者CTRL+C. (3)在dos中以及mysql中修改mysql的root密码 --在dos中,即不需要进入mysq

数据库中简单的增删改查(CRUD)

一切都是基于数据,而对数据的管理都离不开数据库.最近学到数据库的简单操作,所以写下这篇文章,总结一下学习到的知识.浅陋之处,多多见谅. 补充一下:一直弄不清SQL Server,Mysql ,以及Oracle的关系.SQL Server是微软的,因为微软系统的市场占有额,所以这款软件在市场上也占用很大份额,而Mysql是一款开源免费的数据库,我们知道关系型数据库最开始是IBM的一个实验室提出的理论,但是当时并没有被IBM公司重视,被Oracle的创始人劳伦斯·埃里森重视,发展壮大起来.但是Ora

Sql Server xml 类型字段的增删改查

1.定义表结构 在MSSM中新建数据库表CommunicateItem,定义其中一个字段ItemContentXml 为xml类型 2.编辑表数据,新增一行,发现xml类型不能通过设计器录入数据. 需要写sql更新或插入. DECLARE @xml XML SET @xml=' <MyHobby> <MyCode>1</MyCode> <MyName>爬山</MyName> </MyHobby> <MyHobby> <