python自动开发之第十九天

一、路由系统,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

时间: 2024-10-09 08:41:50

python自动开发之第十九天的相关文章

python自动开发之第二十一天

一.请求周期 url> 路由 > 函数或类 > 返回字符串或者模板语言? 1.Form表单提交: 提交 -> url > 函数或类中的方法 - .... HttpResponse('....') render(request,'index.html') redirect('/index/') 用户 < < 返回字符串 (当接收到redirect时)自动发起另外一个请求 --> url ..... 2.Ajax提交: $.ajax({ url: '/index

Python - 错误和异常 - 第十九天

Python 错误和异常 作为 Python 初学者,在刚学习 Python 编程时,经常会看到一些报错信息,在前面我们没有提及,这章节我们会专门介绍. Python 有两种错误很容易辨认:语法错误和异常. 语法错误 Python 的语法错误或者称之为解析错,是初学者经常碰到的,如下实例 >>>while True print('Hello world')  File "<stdin>", line 1, in ?    while True print(

python自动开发之(算法)第二十七天

1.什么是算法? 算法(Algorithm):一个计算过程,解决问题的方法 2.复习:递归 递归的两个特点:(1) 调用自身 (2)结束条件 def func1(x): print(x) func1(x-1) def func2(x): if x>0: print(x) func2(x+1) def func3(x): if x>0: print(x) func3(x-1) def func4(x): if x>0: func4(x-1) print(x) func1和func2不是递归

Python开发【第二十二篇】:Web框架之Django【进阶】

Python开发[第二十二篇]:Web框架之Django[进阶] 猛击这里:http://www.cnblogs.com/wupeiqi/articles/5246483.html 博客园 首页 新随笔 联系 订阅 管理 随笔-124  文章-127  评论-205 Python之路[第十七篇]:Django[进阶篇 ] Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻

Python开发【第十六篇】:AJAX全套

Python开发[第十六篇]:AJAX全套 概述 对于WEB应用程序:用户浏览器发送请求,服务器接收并处理请求,然后返回结果,往往返回就是字符串(HTML),浏览器将字符串(HTML)渲染并显示浏览器上. 1.传统的Web应用 一个简单操作需要重新加载全局数据 2.AJAX AJAX,Asynchronous JavaScript and XML (异步的JavaScript和XML),一种创建交互式网页应用的网页开发技术方案. 异步的JavaScript:使用 [JavaScript语言] 以

Senparc.Weixin.MP SDK 微信公众平台开发教程(十六):AccessToken自动管理机制

Senparc.Weixin.MP SDK 微信公众平台开发教程(十六):AccessToken自动管理机制 在<Senparc.Weixin.MP SDK 微信公众平台开发教程(八):通用接口说明>中,我介绍了获取AccessToken(通用接口)的方法. 在实际的开发过程中,所有的高级接口都需要提供AccessToken,因此我们每次在调用高级接口之前,都需要执行一次获取AccessToken的方法,例如: 1 var accessToken = AccessTokenContainer.

Python开发【第二十篇】:缓存

Python开发[第二十篇]:缓存redis&Memcache 点击这里 Python之路[第九篇]:Python操作 RabbitMQ.Redis.Memcache.SQLAlchemy Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memcached基于一个存储键/值对的hashmap.其守护进程(daemon )是用C写的,但是客户端可

第十五章:Python の Web开发基础(二)

本課主題 JavaScript 介绍 DOM 介绍 jQuery 介绍 JavaScript 介绍 JavaScript 是一门编程语言,它可以让网页动起来的,JavaScript 的变量有两种,一个是局部变量:一个是全区变量.怎么分啦? a = 123; // 全区变量 var a = 123; // 局部变量 JavaScript 的数据类型 JavaScript 的数字类型 parseInt: y = "111" "111" r2 = parseInt(y)

Python开发【第十八篇】:MySQL(二)

Python开发[第十八篇]:MySQL(二) 视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需使用[名称]即可获取结果集,并可以将其当作表来使用. SELECT * FROM ( SELECT nid, NAME FROM tb1 WHERE nid > 2 ) AS A WHERE A. NAME > 'alex'; 临时表搜索 1.创建视图 --格式:CREATE VIEW 视图名称 AS SQL语句 CREATE VIEW v