一、路由系统,URL
  1、函数及类

    函数:url(r'^index/', views.index),     

    类:url(r'^home/', views.Home.as_view()),
  2、顺序

    url(r'^detail-(\d+)-(\d+).html', views.detail),
  3、字典

    url(r'^detail-(?P<nid>\d+)-(?P<uid>\d+).html', views.detail)
  PS:
    def detail(request, *args,**kwargs):
      pass

  实战:
  a.
    url(r'^detail-(\d+)-(\d+).html', views.detail),
    def func(request, nid, uid):
      pass

    def func(request, *args):
      args = (2,9)

    def func(request, *args, **kwargs):
      args = (2,9)

  b.
  url(r'^detail-(?P<nid>\d+)-(?P<uid>\d+).html', views.detail)
    def func(request, nid, uid):
      pass

    def funct(request, **kwargs):
      kwargs = {'nid': 1, 'uid': 3}

      def func(request, *args, **kwargs):
        args = (2,9)
  4、 name

  对URL路由关系进行命名, ***** 以后可以根据此名称生成自己想要的URL *****

    url(r'^asdfasdfasdf/', views.index, name='i1'),
    url(r'^yug/(\d+)/(\d+)/', views.index, name='i2'),
    url(r'^buy/(?P<pid>\d+)/(?P<nid>\d+)/', views.index, name='i3'),

    def func(request, *args, **kwargs):
      from django.urls import reverse

    url1 = reverse('i1') # asdfasdfasdf/
    url2 = reverse('i2', args=(1,2,)) # yug/1/2/
    url3 = reverse('i3', kwargs={'pid': 1, "nid": 9}) # buy/1/9/


    xxx.html

    {% url "i1" %} # asdfasdfasdf/
    {% url "i2" 1 2 %} # yug/1/2/
    {% url "i3" pid=1 nid=9 %} # buy/1/9/

    注:
      # 当前的URL
      request.path_info
  5、多级路由

    project/urls.py
    from django.conf.urls import url,include
    from django.contrib import admin

    urlpatterns = [
      url(r'^cmdb/', include("app01.urls")),
      url(r'^monitor/', include("app02.urls")),
    ]

    app01/urls.py
    from django.conf.urls import url,include
    from django.contrib import admin
    from app01 import views

    urlpatterns = [
      url(r'^login/', views.login),
    ]

    app02/urls.py
    from django.conf.urls import url,include
    from django.contrib import admin
    from app02 import views    urlpatterns = [      url(r'^login/', views.login),    ]


  6、默认值(欠)

  7、命名空间(欠)


二、视图
  1、获取用户请求数据
    request.GET
    request.POST
    request.FILES
    PS:
      GET:获取数据
      POST:提交数据

  2、checkbox等多选的内容
    request.POST.getlist()
  3、上传文件
    # 上传文件,form标签做特殊设置
    obj = request.FILES.get('fafafa')
    obj.name
    f = open(obj.name, mode='wb')
    for item in obj.chunks():
    f.write(item)
    f.close()

  4、FBV & CBV
    function base view
    url.py
      index -> 函数名
    view.py
      def 函数(request):
      ...
    ====》
    /index/ -> 函数名
    /index/ -> 类    

    ====》
    建议:两者都用

  5、装饰器
    欠

三、ORM操作
    select * from tb where id > 1
    # 对应关系
    models.tb.objects.filter(id__gt=1)
    models.tb.objects.filter(id=1)
    models.tb.objects.filter(id__lt=1)

  创建类

  a. 先写类
    from django.db import models

    # app01_userinfo
      class UserInfo(models.Model):
    # id列,自增,主键
    # 用户名列,字符串类型,指定长度
      username = models.CharField(max_length=32)
      password = models.CharField(max_length=64)

  b. 注册APP

    INSTALLED_APPS = [
      'django.contrib.admin',
      'django.contrib.auth',
      'django.contrib.contenttypes',
      'django.contrib.sessions',
      'django.contrib.messages',
      'django.contrib.staticfiles',
      'app01',
    ]
  c. 执行命令
    python manage.py makemigrations
    python manage.py migrate

  d. ********** 注意 ***********
    Django默认使用MySQLdb模块链接MySQL
    主动修改为pymysql,在project同名文件夹下的__init__文件中添加如下代码即可:
    import pymysql
    pymysql.install_as_MySQLdb()

  1. 根据类自动创建数据库表
    # app下的models.py
      python manage.py makemigrations
      python manage.py migrate


  字段:
  字符串类型
  数字
  时间
  二进制
  自增(primary_key=True)
  字段的参数:
    null -> db是否可以为空
    default -> 默认值
    primary_key -> 主键
    db_column -> 列名
    db_index -> 索引
    unique -> 唯一索引
    unique_for_date ->
    unique_for_month
    unique_for_year
    auto_now -> 创建时,自动生成时间
    auto_now_add -> 更新时,自动更新为当前时间

  # obj = UserGroup.objects.filter(id=1).update(caption='CEO')
  # obj = UserGroup.objects.filter(id=1).first()
  # obj.caption = "CEO"
  # obj.save()

  choices -> django admin中显示下拉框,避免连表查询
  blank -> django admin是否可以为空
  verbose_name -> django admin显示字段中文
  editable -> django admin是否可以被编辑
  error_messages -> 错误信息欠
  help_text -> django admin提示
  validators -> django form ,自定义错误信息(欠)

  创建 Django 用户:python manage.py createsuperuser

  2. 根据类对数据库表中的数据进行各种操作
    一对多:
    a. 外键
    b.
    外键字段_id
    c.
    models.tb.object.create(name='root', user_group_id=1)
    d.
    userlist = models.tb.object.all()
    for row in userlist:
    row.id
    row.user_group_id
    row.user_group.caption

python自动开发之(django)第十九天的更多相关文章

  1. python自动开发之第二十四天(Django)

    一.ModelForm操作及验证 1.class Meta:class Meta: #注意以下字段不能加逗号 model = models.UserInfo #这里的all代指所用的字段,也可以是一个 ...

  2. python自动开发之第二十五天

    一.组合搜索 参考: http://www.cnblogs.com/ccorz/p/5985205.html 二.JSONP 1.在同源策略下,在某个服务器下的页面是无法获取到该服务器以外的数据的,但 ...

  3. python自动开发之第二十三天(Django)

    一.一大波model操作 1. 创建数据库表 # 单表 # app01_user ==> tb1 # users class User(models.Model): name = models. ...

  4. Python Web开发:使用Django框架创建HolleWorld项目

    开发环境搭建 Python环境安装 下载地址:https://www.python.org/downloads// Django安装 打开Windows CMD输入pip install django ...

  5. python自动开发之第二十一天

    一.请求周期 url> 路由 > 函数或类 > 返回字符串或者模板语言? 1.Form表单提交: 提交 -> url > 函数或类中的方法 - .... HttpResp ...

  6. python自动开发之第十八天

    一.JS正则 test - 判断字符串是否符合规定的正则 rep = /\d+/; rep.test("asdfoiklfasdf89asdfasdf") # true rep = ...

  7. python自动开发之第十三天

    1.Paramiko模块下的demo.py程序     前面利用Python中的Paramiko模块可以进行SSH的连接,以及用来传送文件(SFTP),但是无论是哪一种方式,连接都是短暂的,并非是长连 ...

  8. python测试开发django-10.django连接mysql

    前言 Django 对各种数据库提供了很好的支持,包括:PostgreSQL.MySQL.SQLite.Oracle.本篇以mysql为例简单介绍django连接mysql进行数据操作 Django连 ...

  9. python测试开发django-7.django模板继承(block和extends)

    前言 打开一个网站时候,点导航栏切换到不同的页面,发现导航部分是不变的,只是页面的主体内容变了,于是就可以写个母模板,其它的子页面继承母模板就可以了. 母模板 可以在母模板中添加多个块标签,每个块标签 ...

随机推荐

  1. gRPC:Google开源的基于HTTP/2和ProtoBuf的通用RPC框架

    gRPC:Google开源的基于HTTP/2和ProtoBuf的通用RPC框架 gRPC:Google开源的基于HTTP/2和ProtoBuf的通用RPC框架 Google Guava官方教程(中文版 ...

  2. redis中各种数据类型对应的jedis操作命令

    redis中各种数据类型对应的jedis操作命令 一.常用数据类型简介: redis常用五种数据类型:string,hash,list,set,zset(sorted set). 1.String类型 ...

  3. winfrom 底层类 验证码 分类: C# 2014-12-17 11:18 258人阅读 评论(0) 收藏

    效果图: 底层类: /// <summary>         /// 生成验证码         /// </summary>         /// <param n ...

  4. dispatch_get_current_queue 废弃

    由于iOS7以后 dispatch_get_current_queue 被废弃,所以需要寻找一个替代的方案. 发现 dispatch_get_current_queue 并没有字面上那么简单. 这个函 ...

  5. docker 下 安装rancher 笔记

    sudo yum update 更新系统环境 curl -sSL https://get.docker.com/ | sh 安装最新docker版本 systemctl start docker.se ...

  6. linux 同步备份 rsyncd 相关设置

    17:25 2013/10/18------------------ rsync linux 同步备份服务器 配置vi /etc/rsyncd.conf 配置文件 /usr/bin/rsync --d ...

  7. android 40 Io编程

    Io编程:内存卡和sd卡.字符串存入内存卡然后读出来. activity: package com.sxt.day06_06; import java.io.FileInputStream; impo ...

  8. QtXML 举例

    QT读取xml有2个方法 对于xml数据比较大的就要用QXmlStreamReader 对于数据比较小的就用QDomDocument,这个比较方便 我这里就是以QDomDocument为主要内容,讲解 ...

  9. 基于GPUImage的实时美颜滤镜

    1.背景 前段时间由于项目需求,做了一个基于GPUImage的实时美颜滤镜.现在各种各样的直播.视频App层出不穷,美颜滤镜的需求也越来越多.为了回馈开源,现在我把它放到了GitHub https:/ ...

  10. PetaPoco 存储过程

    1 执行不带参数的存储过程 public List<dynamic> ceshiProc() { string sql = @"EXEC [dbo].[p_ceshi1]&quo ...