一、回顾总结

https://www.cnblogs.com/maple-shaw/articles/9323320.html

1. 视图
1. CBV 和 FBV
from django.views import View class AddPublisher(View): def dispatch(self, request, *args, **kwargs): ret = super().dispatch(request, *args, **kwargs) return ret def get(self,request):
pass def post(self,request):
pass
使用:
url(r'^add_publisher/', views.AddPublisher.as_view()), 2. CBV的简单的流程
1. AddPublisher.as_view()得到一个view函数
url(r'^add_publisher/', view),
2. 请求到来的时候 执行view:
1. 实例化AddPublisher的类,赋值给self
2. 执行dispatch方法
3. 通过反射获取到get或者post的方法
4. 执行get或者post方法,返回HttpResponse对象
3. 装饰器的使用
1. FBV 正常使用
@装饰器 2. CBV
from django.utils.decorators import method_decorator 1. 给get或者post方法加
2. 给dispatch方法加
3. 给类加(写name='get')
4. request
request.method 请求方法 GET POST
request.GET URL传参 {}
request.POST form表单传的参数
request.body 请求体
request.FILES 上传的文件
request.path_info URL路径 不包含域名和URL参数 request.get_full_path() URL路径包含URL参数
request.get_host() 获取IP和端口
5. response 1. HttpResponse('字符串') —》 页面看到的就是字符串 content—type: text/html;charset=utf8
2. render(request,'HTML文件名',{参数}) ——》返回一个页面
3. redirect('/index/') 跳转 重定向 返回一个响应头 Location:'/index/'
4. JsonResponse(字典) content—type: application/json
返回列表时 safe=False
JsonResponse(data,safe=False) 2. 路由
1.
from django.conf.urls import url urlpatterns =[
url(正则表达式,视图,参数,name)
url(正则表达式,视图,参数,name)
url(正则表达式,视图,参数,name)
]
2. 正则表达式
加$
[0-9] /d
+ 一个或多个
?0个或1个
* 0个或多个
. 除了换行符的所有 3. 分组和命名分组 url(r'book/[0-9]{4}/[0-9]{2}/',views.book) 无名分组:
url(r'book/([0-9]{4})/([0-9]{2})/',views.book)
按照位置传参的方式传给视图 命名分组
url(r'book/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/',views.book)
按照关键字传参的方式给视图 捕获到的参数都是字符串 4. 命名url和url的反向解析 url(r'home',view,home,name='home')
url(r'book/([0-9]{4})/([0-9]{2})/',views.book,name='book')
url(r'book/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/',views.book,name='book2') 视图中反向解析URL:
from django.shortcuts import reverse reverse('home') ——》 /home/
reverse('book',args=('','')) ——》/book/1999/08/
reverse('book2',kwargs={'year':'','month':''}) ——》 /book/1998/08/ 模板中反向解析URL:
{% url 'home' %} ——》 /home/
无名分组: {% url 'book' '' '' %} ——》/book/1999/08/ 有名分组:
{% url 'book' '' '' %} ——》/book/1999/08/
{% url 'book' year='' month='' %} ——》/book/1999/08/
{% url 'book' month='' year='' %} ——》/book/1999/08/ 5. include
from app01 import urls as app01_urls
from app02 import urls as app02_urls url('app01/', include(app01_urls)),
url('app02/', include(app02_urls)) url('app01/', include('app01.urls')),
url('app02/', include('app02.urls')) 5. namespace 3. ORM
1. mysql的配置
1. 创建mysql数据库
2. settings配置
ENGINE: 'mysql'
NAME: '数据库名称'
HOST:IP
PORT: 3306
USER: 'root'
PASSWORD: '' 3. 告诉django使用pymysql来连接mysql数据库
在项目同名的文件夹下的__init__.py中写:
import pymysql
pymysql.install_as_MySQLdb() 4. 创建model
class Person(models.Model)
name = models.CharField(max_length=32) 5. 执行两条数据库命令
python manage.py makemigrations # 记录models的变更记录
python manage.py migrate # 把变革记录更新到数据库中 2. ORM操作 1. 查
models.Person.objects.all() # 查所有
models.Person.objects.get(id=1,name='xxx') # 查一个对象 满足条件的
models.Person.objects.filter(id=1,name='xxx') # 查询满足条件的所有对象 列表
models.Person.objects.filter(id=1,name='xxx').order_by('id') 属性:
pub_obj.name 外键的 book
book_obj.name
book_obj.publisher ——》 这是书籍关联的出版社对象
book_obj.publisher_id ——》 这是数据库存的数据
book_obj.publisher.id
book_obj.publisher.name 多对多 author author.name author.books ——》 多对多的管理对象
author.books.all() 所有作者关联的书籍对象列表 2. 增加:
models.Publisher.objects.creatte(name='xxxx') 外键
models.Book.objects.creatte(name='xxxx',publisher=pub_obj)
models.Book.objects.creatte(name='xxxx',publisher_id=pub_obj.id) 多对多 author_obj = models.Author.objects.creatte(name='xxx')
author_obj.books.set([1,2,3]) 3. 删除
models.Publisher.objects.get(id=1).delete()
models.Publisher.objects.filter(id=1).delete 4. 修改 pub_obj.name = new_name
pub_obj.save() book_obj.name= new_name
book_obj.publisher = new_pub_obj
book_obj.publisher_id = 2
book_obj.save() author_obj.name=new_name
author_obj.save()
author_obj.books.set([1,2])

回顾总结

二、预习和拓展

1.上台阶问题

    

    

def  f(n):
if n ==1:
return 1
elif n==2:
return 2
elif n ==3:
return 4
return f(n-1) + f(n-2) + f(n-3)

上台阶代码实现

2. 自定义固定长度char字段

 

class MyCharField(models.Field):
def __init__(self,max_length,*args,**kwargs):
self.max_length = max_length
super(MyCharField,self).__init__(max_length,*args,**kwargs) def db_type(self,connection):
return "char(%s)" % self.max_length

MyCharField

  cname = MyCharField(max_length=25)

2.ORM查!

python全栈开发day67--字段类型、字段属性、ORM回顾的更多相关文章

  1. python 全栈开发,Day54(jQuery的属性操作,使用jQuery操作input的value值,jQuery的文档操作)

    昨日内容回顾 jQuery 宗旨:write less do more 就是js的库,它是javascript的基础上封装的一个框架 在前端中,一个js文件就是一个模块 一.用法: 1.引入包 2.入 ...

  2. python 全栈开发,Day99(作业讲解,DRF版本,DRF分页,DRF序列化进阶)

    昨日内容回顾 1. 为什么要做前后端分离? - 前后端交给不同的人来编写,职责划分明确. - API (IOS,安卓,PC,微信小程序...) - vue.js等框架编写前端时,会比之前写jQuery ...

  3. Python全栈开发【面向对象进阶】

    Python全栈开发[面向对象进阶] 本节内容: isinstance(obj,cls)和issubclass(sub,super) 反射 __setattr__,__delattr__,__geta ...

  4. Python全栈开发【面向对象】

    Python全栈开发[面向对象] 本节内容: 三大编程范式 面向对象设计与面向对象编程 类和对象 静态属性.类方法.静态方法 类组合 继承 多态 封装 三大编程范式 三大编程范式: 1.面向过程编程 ...

  5. Python全栈开发【模块】

    Python全栈开发[模块] 本节内容: 模块介绍 time random os sys json & picle shelve XML hashlib ConfigParser loggin ...

  6. Python全栈开发【基础四】

    Python全栈开发[基础四] 本节内容: 匿名函数(lambda) 函数式编程(map,filter,reduce) 文件处理 迭代器 三元表达式 列表解析与生成器表达式 生成器 匿名函数 lamb ...

  7. Python全栈开发【基础三】

    Python全栈开发[基础三]  本节内容: 函数(全局与局部变量) 递归 内置函数 函数 一.定义和使用 函数最重要的是减少代码的重用性和增强代码可读性 def 函数名(参数): ... 函数体 . ...

  8. Python全栈开发【基础二】

    Python全栈开发[基础二] 本节内容: Python 运算符(算术运算.比较运算.赋值运算.逻辑运算.成员运算) 基本数据类型(数字.布尔值.字符串.列表.元组.字典) 其他(编码,range,f ...

  9. python 全栈开发之路 day1

    python 全栈开发之路 day1   本节内容 计算机发展介绍 计算机硬件组成 计算机基本原理 计算机 计算机(computer)俗称电脑,是一种用于高速计算的电子计算机器,可以进行数值计算,又可 ...

随机推荐

  1. git与eclipse集成之文件回退

    1.1. 文件回退 1.1.1.        添加或修改文件回退,选择要回退的文件,右键Overwrite 1.1.2.        删除文件回退 选择要回退的文件,右键Overwrite 文件变 ...

  2. zabbix3.0.4利用iostat工具监控centos主机磁盘IO

    该监控基于iostat,然后iostat 命令用来监视系统输入/输出设备负载 1.安装IOSTAT工具 # yum install sysstat -y 测试iostat 查看所有硬盘io # ios ...

  3. java对图片进行透明化处理

    package utils; import java.awt.Graphics2D; import java.awt.image.BufferedImage; import java.io.File; ...

  4. django-form介绍

    Django form表单   目录 普通方式手写注册功能 views.py login.html 使用form组件实现注册功能 views.py login2.html 常用字段与插件 initia ...

  5. ie.360,qq浏览器这种ie内核浏览器默认阻止弹窗

  6. JVM·垃圾收集器与内存分配策略之对象是否可被回收!

    1.判断对象已经死去/不再被引用.     1.1.引用计数算法:给对象添加引用计数器,有个地方引用就+1,引用失效就-1.任何时刻,引用为0,即判断对象死亡.         1.1.1.优点:实现 ...

  7. jQuery-lazyload参数

    1.placeholder placeholder:'图片地址',用图片提前占据将要加载的图片的位置. 2.effect effect:‘fadeIn’ 表示用何种效果载入,eg:show()直接加载 ...

  8. headless&unittest

    为什么要使用 headless 测试? headless broswer 可以给测试带来显著好处: 对于 UI 自动化测试,少了真实浏览器加载 css,js 以及渲染页面的工作.无头测试要比真实浏览器 ...

  9. WinSCP安装与使用

      WinSCP 是一个 Windows 环境下使用的 SSH(Source Shell)的开源图形化 SFTP(SSH File Transfer Protocol) 客户端.同时支持 SCP(So ...

  10. Confluence 6 SQL Server 输入你的数据库细节

    Confluence 的安装向导将会指导你一步一步的在 Confluence 中配置安装 SQL Server 数据库. 使用 JDBC 连接(默认) JDBC 是推荐的连接你的 Confluence ...