python运维开发(二十)----models操作、中间件、缓存、信号、分页

内容目录

  • select Form标签数据库操作
  • models操作F/Q
  • models多对多表操作
  • Django中间件
  • 缓存
  • 信号
  • 分页

select Form标签补充

在上一节中我们可以知道Form标签有两个作用,一个做用户提交数据验证,一个是生成HTML标签

在生成HTML标签中可以生成select标签,select的选项数据我们可以在数据库中查询读取到。

class UserType(models.Model):
    caption = models.CharField(max_length=16)

class UserInfo(models.Model):
    username = models.CharField(max_length=32)
    pwd = models.CharField(max_length=32)
    user_type = models.ForeignKey(‘UserType‘)

#python3 manage.py makemigrations
#python3 migrate

models生成表

from app01 import models
class IndexForm(forms.Form):
    # c = [
    #     (1,‘CEO‘),
    #     (2,‘COO‘)
    # ]
    c = models.UserType.objects.all().values_list(‘id‘,‘caption‘)
    user_type_id = forms.IntegerField(widget=forms.Select(choices=c))

    def __init__(self,*args, **kwargs):
        # 父类构造方法:1、获取所有静态字段   2、fields = []
        super(IndexForm, self).__init__(*args, **kwargs)

        # print(self.fields[‘user_type_id‘].widget.choices)
        self.fields[‘user_type_id‘].widget.choices = models.UserType.objects.all().values_list(‘id‘,‘caption‘)

def index(request):
    # for i in range(10):
    #     models.UserType.objects.create(caption=‘CE‘+str(i))
    # c = models.UserType.objects.all().count()
    # print(c)
    form = IndexForm()
    return render(request, ‘index.html‘, {‘form‘: form})

Views 代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title></title>
</head>
<body>
    <h1>Index</h1>
    {{ form.user_type_id }}

</body>
</html>

前端Html

注意:普通创建完读完数据库数据之后,启动django状态,如果在向数据库中插入数据,页面不会发生变化,因为c=models.UserType.objects.all().values_list(‘id‘,‘caption‘)属于静态对象,如果要查看到更新的数据,可以重启下django就可以了,如果不想重启的话需要自定义__init__构造方法。

models F/Q操作

F:
temp = salary+500
models.UserInfo.objects.filter().update(salary=temp)
update userinfo set salary=salary+500 

from django.db.models import F
models.UserInfo.objects.filter().update(salary=F(‘salary‘)+500)

Q:
构造搜索条件
1、传参
models.UserInfo.objects.filter(id=123,name=‘alex‘)

2、传字典
d = {‘id‘: 123, ‘name‘:‘alex‘}
models.UserInfo.objects.filter(**d)

<input name=‘id‘ />
<input name=‘name‘ />
获取用户输入,并构造成字典:
models.UserInfo.objects.filter(**c)
3、传Q对象
models.UserInfo.objects.filter(Q对象)

from django.db.models import Q

# q1 = Q()
# q1.connector = ‘OR‘
# q1.children.append((‘id‘, 1))
# q1.children.append((‘id‘, 2))
# q1.children.append((‘id‘, 3))

# models.Tb1.objects.filter(q1)

# con = Q()
#
# q1 = Q()
# q1.connector = ‘OR‘
# q1.children.append((‘id‘, 1))
# q1.children.append((‘id‘, 2))
# q1.children.append((‘id‘, 3))
#
# q2 = Q()
# q2.connector = ‘OR‘
# q2.children.append((‘status‘, ‘在线‘))
#
# con.add(q1, ‘AND‘)
# con.add(q2, ‘AND‘)
#
# models.Tb1.objects.filter(con)

models多对多操作

	- 创建
		a. 方式一:
			class B2G(models.Model):
				b_id = models.ForeignKey(‘Boy‘)
				g_id = models.ForeignKey(‘Girl‘)

			class Boy(models.Model):

				username = models.CharField(max_length=16)

			class Girl(models.Model):

				name = models.CharField(max_length=16)

		b. 方式二:
			class Boy(models.Model):

				username = models.CharField(max_length=16)
				# girl_set
			class Girl(models.Model):

				name = models.CharField(max_length=16)

				b = models.ManyToManyField(‘Boy‘)

	- 操作:
		添加:
			正向
				g1 = models.Girl.objects.get(id=1)

				g1.b.add(models.Boy.objects.get(id=1))
				g1.b.add(1)

				bs = models.Boy.objects.all()
				g1.b.add(*bs)
				g1.b.add(*[1,2,3])

			反向
				b1 = models.Boy.objects.get(id=1)
				b1.girl_set.add(1)
				b1.girl_set.add(models.Girl.objects.all())

				b1.girl_set.add(*[1,2,3,4])
				...
		删除:
			g1 = models.Girl.objects.get(id=1)
			g1.b.clear() # 清空和girl ID=1所关联的所有数据

			g1.b.remove(2)
			g1.b.remove(*[1,2])

		查询:
			g1 = models.Girl.objects.get(id=1) # SQL
			g1.b.all()						   # SQL
			g1.b.filter().count()

			b1 = models.Boy.objects.get(id=1)
			b1.girl_set.all()

			models.Girl.objects.all().values(‘id‘,‘name‘, ‘b__username‘)
			models.Boy.objects.all().values(‘id‘,‘username‘, ‘girl__name‘)
		更新:

		ORM:
			python操作数据库模块:
				MySQLdb
				pymysql

		原生SQL
			# from django.db import connection
			# cursor = connection.cursor()
			# cursor.execute("""SELECT * from tb where name = %s""", [‘Lennon‘])
			# row = cursor.fetchone()

Django中间件

配置文件:
			MIDDLEWARE_CLASSES

		写类:
			process_request
			process_view
			process_exception
			process_response

		1.10
		配置文件:
			MIDDLEWARE = 

		原版本:
			如果process_request中有return, 则所有的process_response执行一遍

缓存

信号

分页 

时间: 2024-11-18 06:22:07

python运维开发(二十)----models操作、中间件、缓存、信号、分页的相关文章

python运维开发(二十五)---cmdb开发

内容目录: 浅谈ITIL CMDB介绍 Django自定义用户认证 Restful 规范 资产管理功能开发 浅谈ITIL TIL即IT基础架构库(Information Technology Infrastructure Library, ITIL,信息技术基础架构库)由英国政府部门CCTA(Central Computing and Telecommunications Agency)在20世纪80年代末制订,现由英国商务部OGC(Office of Government Commerce)负

python运维开发(二十一)----文件上传和验证码+session

内容目录: 文件上传 HTML Form表单提交 ajax提交 原生ajax提交 jQuery Ajax提交 验证码+session 文件和图片的上传功能

Python运维开发基础01-语法基础【转】

开篇导语 整个Python运维开发教学采用的是最新的3.5.2版,当遇到2.x和3.x版本的不同点时,会采取演示的方式,让同学们了解. 教学预计分为四大部分,Python开发基础,Python开发进阶,Python网页编程,Python项目实战 Python开发基础分为语法基础篇,文件基础篇,函数基础篇,模块基础篇 语法基础篇中,我着重希望训练同学的是作为开发应该具备的一种逻辑思路. 文件基础篇中,我们需要练习的是如何将数据永久性的存储在硬盘上,提供读,写. 函数基础篇中,我重点是要引导同学们构

python运维开发笔记4

1.函数如何被调用,通过return返回值来调用 2.生成器和return区别 yield 生成器返回对象,可以迭代 可以执行 glob模块 类似shell中的正则匹配 shlex模块  Popen 将命令参数直接分词 cmd = "ps ax -o pid,ppid,cmd" shlex.split(cmd) ['ps','ax','-o','pid,ppid,cmd'] ['mysql','-u','root','-p123','-e','show processlist'] p

python运维开发笔记5

diff -Nur Diff和patch是Linux标配的工具.在Windows上,也有移植的版本可以使用. 使用中注意: 1.保证文件名完全相同,避免只有大小写不同的文件存在. 2.Diff只能比较文本文件,二进制文件只能判断是否相同,不能记录差异.Diff根据文件的前几个字节判断文件是不是文本文件. 使用方法: 可以对单个文件或者整个目录树进行处理. 以最实用的方式举例: diff –Nur dir_old dir_new > dir.patch patch –p0 < dir.patch

Python运维开发基础

Python基础知识分为以下几块 1.Python概述 2.基础语法 3.数据结构 4.Python进阶 5.实训案例 一.Python概述 1.Python简介 2.Hello World 3.搭建开发环境 4.习题 Python简介 尽管我是学计算机出身的,但是我对Python的认识是在毕业后.Python是我喜欢的语言,简洁,优美,容易使用.重要的一点是他是开源的项目. 官方网站 https://www.python.org 学习网站 http://www.okpython.com 对于简

重磅|0元学 Python运维开发,别再错过了

51reboot 运维开发又双叒叕的搞活动了,鉴于之前 51reboot 的活动反馈,每次活动结束后(或者已经结束了很长时间)还有人在问活动的事情.这一次小编先声明一下真的不想在此次活动结束后再听到类似下面的话了 我之前不知道有活动 (这个锅小编我背了) 这个活动还有吗? 我想了解一下这个活动 跟我说可以给我按活动价算吗? .......... 针对以上类似的询问小编在此统一回复大家: 好了,接下来进入今天的重中之重 本次活动:Python 运维开发——18天训练营 本课程为:网络班+面授班(北

python运维开发常用模块(一)psutil

1.模块简介 psutil是一个跨平台库(http://code.google.com/p/psutil/),能够轻 松实现获取系统运行的进程和系统利用率(包括CPU.内存.磁盘.网 络等)信息.它主要应用于系统监控,分析和限制系统资源及进程的管 理.它实现了同等命令行工具提供的功能,如ps.top.lsof.netstat. ifconfig.who.df.kill.free.nice.ionice.iostat.iotop.uptime. pidof.tty.taskset.pmap等.目前

python运维开发常用模块(四)文件对比模块difflib

1.difflib介绍 difflib作为 Python的标准库模块,无需安装,作用是对比文本之间的差异,且支持 输出可读性比较强的HTML文档,与Linux下的diff命令相似.我们可以 使用difflib对比代码.配置文件的差别,在版本控制方面是非常有用. Python 2.3或更高版本默认自带difflib模块,无需额外安装. 示例1:两个字符串的差异对比 [[email protected] part2]$ cat simple1.py #!/usr/bin/python #_*_cod