Python 20th Day

Model

  • 创建表

  • from django.db import models
    
    class userinfo(models.Model):
        name = models.CharField(max_length=30)
        email = models.EmailField()
        memo = models.TextField()
  • 基本操作
  • # 增
        #
        # models.Tb1.objects.create(c1=‘xx‘, c2=‘oo‘)  增加一条数据,可以接受字典类型数据 **kwargs
    
        # obj = models.Tb1(c1=‘xx‘, c2=‘oo‘)
        # obj.save()
    
        # 查
        #
        # models.Tb1.objects.get(id=123)         # 获取单条数据,不存在则报错(不建议)
        # models.Tb1.objects.all()               # 获取全部
        # models.Tb1.objects.filter(name=‘seven‘) # 获取指定条件的数据
    
        # 删
        #
        # models.Tb1.objects.filter(name=‘seven‘).delete() # 删除指定条件的数据
    
        # 改
        # models.Tb1.objects.filter(name=‘seven‘).update(gender=‘0‘)  # 将指定条件的数据更新,均支持 **kwargs
        # obj = models.Tb1.objects.get(id=1)
        # obj.c1 = ‘111‘
        # obj.save()                                                 # 修改单条数据
  • 双下划线
    • 限定条件
    •     # 获取个数
          #
          # models.Tb1.objects.filter(name=‘seven‘).count()
      
          # 大于,小于
          #
          # models.Tb1.objects.filter(id__gt=1)              # 获取id大于1的值
          # models.Tb1.objects.filter(id__lt=10)             # 获取id小于10的值
          # models.Tb1.objects.filter(id__lt=10, id__gt=1)   # 获取id大于1 且 小于10的值
      
          # in
          #
          # models.Tb1.objects.filter(id__in=[11, 22, 33])   # 获取id等于11、22、33的数据
          # models.Tb1.objects.exclude(id__in=[11, 22, 33])  # not in
      
          # contains
          #
          # models.Tb1.objects.filter(name__contains="ven")
          # models.Tb1.objects.filter(name__icontains="ven") # icontains大小写不敏感
          # models.Tb1.objects.exclude(name__icontains="ven")
      
          # range
          #
          # models.Tb1.objects.filter(id__range=[1, 2])   # 范围bettwen and
      
          # 其他类似
          #
          # startswith,istartswith, endswith, iendswith,
      
          # order by
          #
          # models.Tb1.objects.filter(name=‘seven‘).order_by(‘id‘)    # asc
          # models.Tb1.objects.filter(name=‘seven‘).order_by(‘-id‘)   # desc
      
          # limit 、offset
          #
          # models.Tb1.objects.all()[10:20]
      
          # group by
          from django.db.models import Count, Min, Max, Sum
          # models.Tb1.objects.filter(c1=1).values(‘id‘).annotate(c=Count(‘num‘))
          # SELECT "app01_tb1"."id", COUNT("app01_tb1"."num") AS "c" FROM "app01_tb1" WHERE "app01_tb1"."c1" = 1 GROUP BY "app01_tb1"."id"
    • 连表操作  
    • class Clothes(models.Model):
          color=models.ForeignKey("Colors")   #与颜色表为外键,颜色表为母表
          description=models.CharField(max_length=10) #描述
          def __str__(self):
              return self.description
      
      class Colors(models.Model):
          colors=models.CharField(max_length=10) #蓝色
          def __str__(self):
              return self.colors
      #颜色为红的服装,description都更新为大美女
      #写法1:
      models.Clothes.objects.filter(color__colors="红").update(description="大美女")
      #写法2:
      models.Clothes.objects.filter(color_id=models.Colors.objects.get(colors="红").id).update(description="大美女")
      #写法3:
      colors_obj=models.Colors.objects.get(colors="红")
      colors_obj.clothes_set.filter(id__gte=1).update(description="大美女")
      #增添子表数据,形式与一对一一致
      #添加颜色为绿的服装:小帅哥
      #方法1:
      models.Clothes.objects.create(color=models.Colors.objects.get(colors="绿"),description="小帅哥")
      #方法1补充:
      models.Clothes.objects.create(color_id=models.Colors.objects.get(colors="绿").id,description="小帅哥")
      #方法2:
      c_obj=models.Clothes(color=models.Colors.objects.get(colors="绿"),description="小帅哥")
      c_obj.save()
时间: 2024-09-30 15:36:50

Python 20th Day的相关文章

Python进制转换(二进制、十进制和十六进制)

#!/usr/bin/env python # -*- coding: utf-8 -*- # 2/10/16 base trans. wrote by srcdog on 20th, April, 2009 # ld elements in base 2, 10, 16. import os,sys # global definition # base = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F] base = [str(x) for x

Python内置函数进制转换的用法

使用Python内置函数:bin().oct().int().hex()可实现进制转换. 先看Python官方文档中对这几个内置函数的描述: bin(x)Convert an integer number to a binary string. The result is a valid Python expression. If x is not a Python int object, it has to define an __index__() method that returns a

Top 10 Algorithms of 20th and 21st Century

Top 10 Algorithms of 20th and 21st Century MATH 595 (Section TTA) Fall 2014 TR 2:00 pm - 3:20 pm, Room 341 Altgeld HallUniversity of Illinois at Urbana-Champaign, Department of Mathematics Instructors : Yuliy Baryshnikov and Anil N. Hirani Schedule:I

python进制转换(二丶八丶十丶十六)

#二进制转换成十进制##v = "0b1111011"##print(type(v))##a = int(v,2)##print(type(a))##print(a) #十进制转换成二进制##v = 18##v = bin(v)##print(v) #八进制转换为十进制##v = "011"##print(int(v,8)) #十进制转化为八进制##v = 30##print(oct(v))##shi = oct(v)##print(int(shi,8)) #十六进

Python学习1-Python和Pycharm的下载与安装

本文主要介绍Python的下载安装和Python编辑器Pycharm的下载与安装. 一.Python的下载与安装 1.下载 到Python官网上下载Python的安装文件,进入网站后显示如下图: 网速访问慢的话可直接在这里下载:python-2.7.11.amd64 在Downloads中有对应的支持的平台,这里我们是在Windows平台下运行,所以点击Windows,出现如下: 在这里显示了Python更新的所有版本,其中最上面两行分别是Python2.X和Python3.X对应的最后更新版本

Python——深入理解urllib、urllib2及requests(requests不建议使用?)

深入理解urllib.urllib2及requests            python Python 是一种面向对象.解释型计算机程序设计语言,由Guido van Rossum于1989年底发明,第一个公开发行版发行于1991年,Python 源代码同样遵循 GPL(GNU General Public License)协议[1] .Python语法简洁而清晰,具有丰富和强大的类库. urllib and urllib2 区别 urllib和urllib2模块都做与请求URL相关的操作,但

python学习_day26_面向对象之封装

1.私有属性 (1)动态属性 在python中用双下划线开头的方式将属性隐藏起来.类中所有双下划线开头的名称,如__x都会自动变形成:_类名__x的形式.这种自动变形的特点是: a.类中定义的__x只能在内部使用,如self.__x,引用的就是变形的结果.b.这种变形其实正是针对外部的变形,在外部是无法通过__x这个名字访问到的.c.在子类定义的__x不会覆盖在父类定义的__x,因为子类中变形成了:_子类名__x,而父类中变形成了:_父类名__x,即双下滑线开头的属性在继承给子类时,子类是无法覆

python面向对象知识点疏理

面向对象技术简介 类: 用来描述具有相同的属性和方法的对象的集合.它定义了该集合中每个对象所共有的属性和方法.对象是类的实例.class 类变量:类变量在整个实例化的对象中是公用的.类变量定义在类中且在函数体之外.类变量通常不作为实例变量使用. 数据成员:类变量或者实例变量用于处理类及其实例对象的相关的数据. 方法重写:如果从父类继承的方法不能满足子类的需求,可以对其进行改写,这个过程叫方法的覆盖,也称为方法的重写. 实例变量:定义在方法中的变量,只作用于当前实例的类. 继承:即一个派生类(de

python实现网页登录时的rsa加密流程

对某些网站的登录包进行抓包时发现,客户端对用户名进行了加密,然后传给服务器进行校验. 使用chrome调试功能断点调试,发现网站用javascript对用户名做了rsa加密. 为了实现网站的自动登录,需要模拟这个加密过程. 网上搜了下关于rsa加密的最简明的解释: rsa加密是非对称加密算法,该算法基于一个十分简单的数论事实:将两个大素数相乘十分容易,但那时想要对其乘积进行因式分解却极其困难,因此可以将乘积公开作为加密密钥,即公钥,而两个大素数组合成私钥.公钥是可发布的供任何人使用,私钥则为自己