业内:

   GET:获取数据

   POST:提交数据

    上传单个数据: request.POST.get(‘’name名‘’)

    上传多选数据: request.POST.getlist('name名')

    上传文件:obj = request.FILES.get('name名')

         obj.chunks()  -生成器

         for item in obj.chunks()

         在form中加入enctype=‘multipart/form-data’

一、路由系统  FBV   CBV

   1,直接 

      url(r'^index/',views.index),    url(r'^home/',views.Home.as_view())

   2.正则表达式的url   'detail-(\d).html'      对应 参数 传入函数

      url(r'detail-(\d+).html',views.detail)

      url(r'detail-(?p<nid>\d+)-(?p<uid>\d+).html',views.detail)

        def detail(request,*args,**kwargs)

   3.name

    对url路由关系进行命名,根据此名称构建想要的url

      url(r'^indexdfd',views.insez,name='i1')

        def func(request,*args,**kwargs):

          from django.urls import reverse

          url1 = reverse('i1')

      xx.html  {%  url  "i1"  %}

      

      url(r'^indexdfd/(\d+)',views.insez,name='i2')

        def func(request,*args,**kwargs):

          from django.urls import reverse

          url2 = reverse('i2,args=(3,)')

   4.url分发机制

    from django.conf.urls import include

    url(r'cmdb/',include('app01.url'))

    url(r'monitor/',include('app02.url'))

   5.默认值

   6.命名空间

  

二、视图系统

    返回数据:

        render(request,"模板的文件路径",{数据名:数据})

        redirect('URL')

        HttpResponse('字符串')

 

四、ORM操作

  django 默认用mysqldb 来连接

  在__init__中加入

  import pymysql

  pymysql.install_as_MySQLdb()

  

  创建表

  1.根据类自动创建数据库表

    #app 中的moudels.py

        class UserInfo(models.model)

        #用户名列,字符串类型,指定长度

        username = models.CharField(max_lenth = 32)

   

    python manage.py makemigrations   #创建表的文件

    python manage.py migrate  #根据文件创建数据库表

  

    如果出现:No changes detected

    在settings 里 installAPP 中  加入 对应的app名称

    如果依然无效,可python manage.py makemigrations <app名称>  #创建表的文件

    在setting 设置 DATABASES  可以选择哪种数据库

    字段:

      字符串类型

      数字类型

      时间类型

      自增(primary_key = True)

    字段参数:

      null        是否为空/    

      default        默认值/

      primary_key    主键

      db_index       索引

      unique        唯一索引

        unique_for_date  对时间做唯一索引

      auto_now     创建时,自动生成时间

      auto_now_add     跟新时,自动生成时间  只用使用obj.save()才有用

      choices      django admin中显示下拉框,避免连表查询

      blank       django admin中表示是否为空

      verbose_name     django admin中显示字段中文

      editable      django admin中是否可被编辑

      error_messages   django admin中提示错误信息

      help_text       django admin中显示帮助信息

      validators      django form,自定义错误信息

  2.根据类对数据库表中的数据进行各种操作

    

    创建数据:

      第一张方式:

      models.UserInfo.objects.create(username='root',password= '123')

      第二种方式:

      obj = models.UserInfo(username='root',password= '123')

       obj.save()

      第三种方式:

      dic = {‘username’:'root','password':'123'}

      models.UserInfo.objects.create(**dic)

    查找数据:

      拿到所有数据:

      result = models.UserInfo.objects.all()  #QuerySet类型 [ obj, obj, obj(id,username,password) ]

      for row in result:

        print(row.id,row.username,row.password)

      条件查询:

      result = models.UserInfo.objects.filter(username='root')

      for row in result:

        print(row.id,row.username,row.password)

      拿第一个:

      result = models.UserInfo.objects.filter(username='root').first()

      拿个数:

      result = models.UserInfo.objects.filter(username='root').count()

      

    删除内容:

    models.UserInfo.objects.filter(id=4).delete()

    跟新内容:

    models.UserInfo.objects.all().update(password='777')

    models.UserInfo.objects.filter(id=3).update(password='777')

    外键:

    在class UserInfo 中加入:

    user_group =  models.ForeignKey('UserGroup',to_field='uid')

    创建时:

    user_group_id = 1

    或:

    user_group = models.UserGroup.objects.filter(id=1).first()  #对象

    

    外键:
      user_group = models.ForeignKey('UserGroup',to_field = 'uid',default=1)

      存入sql中为:user_group_id

      获取方法:
      user_list = Userinfo.objects.all()
      for row in user_list:
        print(row.user_group_id)
        print(row.user_group) #row.user_group代表一个对象
        #row.user_group_id ==== row.user_group.uid

 

添加方法:
model.Userinfo.objects.create(
username = 'root'
password = '123'
email = '3@qq.com'
user_group_id = 1 ) 或者:
model.Userinfo.objects.create(
username = 'root'
password = '123'
email = '3@qq.com'
user_group = models.UserGroup.objects.filter(id=1).first() )

  

外键实例

  一个主机管理的实例:

#主机管理
class Host(models.Model):
nid = models.AutoField(primary_key) = True
hostname = models.CharField(max_length=32,db_index=True)
ip = models.GenericIPAddressField(db_index=True) #加上索引,ipaddressfield已经被generic替换了
port = models.IntegerField()
business = models.ForeignKey(to = 'Business',to_field='id') class Business(models.Model):
#id
caption = models.CharField(max_length=32)
code = models.CharField(max_length=32,null=True,default = ='sa')

  

通过外键操作:

#获取
v = models.Business.objects.all() #以对象方式
#或者获取指定列,内部元素是字典:
v = models.Business.objects.all().values('id','caption') #以字典方式
#获取元祖[(1,运维),(2,开发)]
v = models.Business.objects.all().values_list('id','caption') #只能按序列查找 #获取到的一个对象,如果不存在就报错
models.Business.objects.get(id=1)
models.Business.objects.filter(id=1) 不存在就为none 外键:
v = models.Host.objects.filter(nid__gt=0)
v[0].business.caption ----->通过.进行跨表查询 使用下划线获取外键内的值 (以字典形式)
v2 =models.Host.objects.filter(nid__gt=0).values('nid','hostname','b_id','b_caption') {{ forloop.counter }} 循环计数
{{ forloop.counter0 }}
{{ forloop.revcounter }}
{{ forloop.revcounter0 }}
{{ forloop.last }} 是否是最后一个循环
{{ forloop.first }} 是否是第一个循环 {{ forloop.parentloop }} 是否是最后一个

  

      

      

      

  

网页编程-Django(一)的更多相关文章

  1. 网页编程-django前传

    1.js正则表达式  http://www.cnblogs.com/wupeiqi/articles/5602773.html test  - 判断字符串是否符合规定的正则 正则表达式: rep = ...

  2. 网页编程工具:EditPlus

    字体:Consolas EditPlus,很土很简单很强大的网页编程工具 http://www.editplus.com/download.html  下载 http://www.cnblogs.co ...

  3. java基础54 网络通讯的三要素及网络/网页编程的概述

    1.概述 网络编程注意解决的是计算机(手机.平板.....)之间的数据传输问题.        网络编程:不需要基于html基础上,就可以进行数据间的传输.比如:FeiQ.QQ.微信.....     ...

  4. 网页编程技术与实例 PDF扫描版

    本书主要包括:Web的概念,使用网页编辑工具制作网页,HTML语言的基本结构,JavaScrip和VBScript脚本语言的编程方法,ASP的概念,ASP对象的属性.方法和事件,SQL语言,数据库建议 ...

  5. 10分钟搭建一个小型网页(python django)(hello world!)

    10分钟搭建一个小型网页(python django)(hello world!) 1.安装django pip install django 安装成功后,在Scripts目录下存在django-ad ...

  6. Batsing的网页编程规范(HTML/CSS/JS/PHP)

    特别注意!!!我这里的前端编程规范不苟同于Bootstrap的前端规范. 因为我和它的目的不同,Bootstrap规范是极简主义,甚至有些没有考虑到兼容性的问题. 我的规范是自己从编程实践中总结出来的 ...

  7. django学习记录--第一个网页“hello django”

    一.安装django 下面两种方法任选其一 1.pip或easy_install 安装 pip install django easy_install django 2.到django官网(https ...

  8. BAT之间的区别(学点网页编程,然后开始研究)

    A: 阿里不就是靠网页起家的吗? T: 腾讯靠客户端. B: 百度是靠网页背后的算法技术支持- 最近网页技术又发布了很多新功能,而现在网页功能也已经很强大了. 不知道自己是不是老了,总觉得不喜欢网页( ...

  9. 网页编程-Djiango(二)

    一.初始Ajax ajax的写法: $.ajax({ url:'/host', type:'POST' data:{'k1':123,'k2':'root'} success:function(dat ...

随机推荐

  1. iOS--------手势识别的详细使用:拖动、缩放、旋转、点击、手势依赖、自定义手势

    1.UIGestureRecognizer介绍 手势识别在iOS上非常重要,手势操作移动设备的重要特征,极大的增加了移动设备使用便捷性. iOS系统在3.2以后,为方便开发这使用一些常用的手势,提供了 ...

  2. NOIP2012开车旅行 【倍增】

    题目 小 A 和小 B 决定利用假期外出旅行,他们将想去的城市从 1 到 N 编号,且编号较小的城市在编号较大的城市的西边,已知各个城市的海拔高度互不相同,记城市 i 的海拔高度为Hi,城市 i 和城 ...

  3. 使用UltraEdit 替换解决---文字中含有逗号的文件,如何把逗号自动转换成为:回车换行呢?

    实际工作中有时经常遇到一个问题: 一行文字中含有逗号,如何把逗号自动转换成为:回车换行呢? 普遍存在的问题,用Ultredit中^r^n(回车换行)也可以完成.提供大家参考. 王乐,李宏宇,张志鹏,刘 ...

  4. 【BZOJ2243】染色(树链剖分)

    题意: 给定一棵有n个节点的无根树和m个操作,操作有2类: 1.将节点a到节点b路径上所有点都染成颜色c: 2.询问节点a到节点b路径上的颜色段数量(连续相同颜色被认为是同一段),如“112221”由 ...

  5. 免费CSS鼠标样式代码大全

    原文发布时间为:2008-08-01 -- 来源于本人的百度文章 [由搬家工具导入] http://5211.91.tc/sb.htm

  6. batch.bat explaination

    1.Echo 命令 打开回显或关闭请求回显功能,或显示消息.如果没有任何参数,echo 命令将显示当前回显设置. 语法 echo [{on|off}] [message] Sample篅echo of ...

  7. JVM指令详解(下)

    九.自增减指令 该指令用于对本地(局部)变量进行自增减操作.该指令第一参数为本地变量的编号,第二个参数为自增减的数量. 比如对于代码:                 int d=10; d++; d ...

  8. php 几种排序模式

    冒泡排序 冒泡排序(Bubble Sort,台湾译为:泡沫排序或气泡排序)是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工>作 ...

  9. 删除指定文件夹下所有的.svn文件夹

      sudo find /目录 -name ".svn" -exec rm -r {} \;

  10. 微信小程序踩坑之一【weui-wxss-master单选按钮图标修改思路】

    小程序原生所带的weui框架做小程序UI实在太方便了,但是他的一些细微变化也是让开发中碰到不少头疼的问题 一直以来单选多选的美化都是设计师重点表达的地方之一 而weui-wxss-master中的单选 ...