Python Web(二)
Infi-chu:
http://www.cnblogs.com/Infi-chu/
一、Django-debug-toolbar
django-debug-toolbar 是一组可配置的面板,可显示有关当前请求/响应的各种调试信息,并在单击时显示有关面板内容的更多详细信息。
github链接:https://github.com/jazzband/django-debug-toolbar
文档链接:http://django-debug-toolbar.readthedocs.io/en/stable/
1.安装
pip install django-debug-toolbar
2.配置
settings.py
# 将debug-toolbar添加到APP配置中 INSTALLED_APPS = [
…
'debug_toolbar',
] # 在中间件中加入DebugToolbarMiddleware MIDDLEWARE = [
# ...
'debug_toolbar.middleware.DebugToolbarMiddleware',
# ...
] # 如果是本机调试,还在将127.0.0.1加入 INTERNAL_IPS INTERNAL_IPS = [‘127.0.0.1’, ]
urls.py
from django.conf import settings
from django.conf.urls import include, url if settings.DEBUG:
import debug_toolbar
urlpatterns = [
url(r'^__debug__/', include(debug_toolbar.urls)),
] + urlpatterns
配置jQuery
DEBUG_TOOLBAR_CONFIG = {
"JQUERY_URL": '//cdn.bootcss.com/jquery/2.2.4/jquery.min.js',
}
# 如果在Django项目中使用了jquery的话就可以直接将这一项置为空,那么django-debug-toolbar 就会使用你项目中用到的jquery:
DEBUG_TOOLBAR_CONFIG = {
"JQUERY_URL": '',
}
二、表与表之间的关系
1.一对一
userinfo 表
| id | name | age |
|---|---|---|
| 1 | 张三 | 12 |
| 2 | 李四 | 58 |
private 表
| id | salary | sp_id |
|---|---|---|
| 1 | 100 | 1 |
| 2 | 400 | 2 |
models.py
class UserInfo(models.Model):
name = models.CharField(max_length=32, null=True)
age = models.IntegerField(null=True) class Private(models.Model):
salary = models.CharField(max_length=32, null=True)
sp = models.OneToOneField("UserInfo", null=True) #oneTooneField: 一对一, 默认要求该字段必须是唯一的 unique 外键关系
插入信息
models.UserInfo.objects.create(name='张三',age=12)
models.Private.objects.create(salary=100,sp_id=1)
查询
#从母表查询子表中的数据
#方法1:res = models.UserInfo.objects.filter(name='张三').first().private.salary #子表表名小写.子表字段名
#方法2:res = models.UserInfo.objects.filter(name='张三').values('private__salary') #从子表查询母表信息
#方法1:res = models.Private.objects.filter(salary='100').first().sp.name
#方法2:res = models.Private.objects.values('sp__name'):
2.一对多
3.多对多(通过关系表)
models.py
class Boy(models.Model):
bname = models.CharField(max_length=30,null=True) class Girl(models.Model):
gname = models.CharField(max_length=30,null=True) class Boy2Girl(models.Model):
b = models.ForeignKey('Boy',null=True)
g = models.ForeignKey('Girl',null=True)
#联合唯一属性
class Meta:
unique_together=[
('b','g')
]
插入信息
import random
boys =[
models.Boy(bname='男1'),
models.Boy(bname='男2'),
models.Boy(bname='男3'),
models.Boy(bname='男4'),
models.Boy(bname='男5'),
models.Boy(bname='男6')
]
res = models.Boy.objects.bulk_create(boys) girls =[
models.Girl(gname='女1'),
models.Girl(gname='女2'),
models.Girl(gname='女3'),
models.Girl(gname='女4'),
models.Girl(gname='女5'),
models.Girl(gname='女6'),
models.Girl(gname='女7'),
models.Girl(gname='女8'),
]
models.Girl.objects.bulk_create(girls) a = [
models.Boy2Girl(b_id=random.randint(1,6),g_id=1),
models.Boy2Girl(b_id=random.randint(1,6),g_id=2),
models.Boy2Girl(b_id=random.randint(1,6),g_id=3),
models.Boy2Girl(b_id=random.randint(1,6),g_id=4),
models.Boy2Girl(b_id=random.randint(1,6),g_id=5),
models.Boy2Girl(b_id=random.randint(1,6),g_id=6),
models.Boy2Girl(b_id=random.randint(1,6),g_id=7),
models.Boy2Girl(b_id=random.randint(1,6),g_id=8),
]
models.Boy2Girl.objects.bulk_create(a)
查询
#通过关系表查询,查boy位男1对于的女的信息
#方法1:res = models.Boy2Girl.objects.filter(b__bname='男1').values('g__gname')
#方法2:
res = models.Boy2Girl.objects.filter(b__bname='男1').all()
for a in res:
print(res.g.gname) #通过boy表查女的信息
#方法1: res = models.Boy.objects.filter(bname='男1').values('boy2girl__g__gname')
#方法2:
res = models.Boy.objects.filter(bname='男1').all()
for a in res:
for b in a.boy2girl_set.all():
print(b.g.gname)
4.多对多(不通过关系表)
models.py
class Boy1(models.Model):
bname = models.CharField(max_length=32, null=True)
g = models.ManyToManyField('Girl', null=True)
#他会生成一个boy1_g的表 class Girl1(models.Model):
gname = models.CharField(max_length=32, null=True)
插入信息
boys =[
models.Boy(bname='男1'),
models.Boy(bname='男2'),
models.Boy(bname='男3'),
models.Boy(bname='男4'),
models.Boy(bname='男5'),
models.Boy(bname='男6')
]
res = models.Boy1.objects.bulk_create(boys)
#
girls =[
models.Girl(gname='女1'),
models.Girl(gname='女2'),
models.Girl(gname='女3'),
models.Girl(gname='女4'),
models.Girl(gname='女5'),
models.Girl(gname='女6'),
models.Girl(gname='女7'),
models.Girl(gname='女8'),
]
models.Girl1.objects.bulk_create(girls)
建立两者关系
- 取出boy的对象
- 在选择其中的g对象,进行add 添加/删除/查询 girl的id
添加(add)
models.Boy1.objects.filter(bname='男1').first().g.add(1,2,3,4,5,2) #会自动去重保持唯一性也不会因为相同而报错
删除(remove)
models.Boy1.objects.filter(bname='男1').first().g.remove(1)
查询(all)
models.Boy1.objects.filter(bname='男1').first().g.all()
清除(clear)
models.Boy1.objects.filter(bname='男1').first().g.clear() #清除所有
【注】
add进行添加时候如果有会自动去重,他自带联合唯一的效果
三、MySQL与Django-orm数据类型对应关系
| 数据类型 | mysql | djamgo-orm |
|---|---|---|
| 数字 | tinyint | 不存在 |
| - | smallint | SmallIntegerField(有符号) PositiveSmallIntegerField(没符号) |
| - | mediumint | 不存在 |
| - | int (unsigned) | IntegerField(有符号)PositiveIntegerField(没符号) |
| - | bigint | BigIntegerField(有符号) PositiveBigIntegerField(没符号) |
| - | decimal | DecimalField |
| - | float | FloatField |
| - | double | 不存在 |
| 字符串 | char | 不存在 |
| - | varchar | CharField |
| - | text | TextField |
| 时间日期 | date | DateField |
| - | datetime | DateTimeField |
| - | timestamp | 不存在 |
四、MySQL与Django-orm数据类型对应属性
null 数据库中字段是否可以为空
db_column 数据库中字段的列名
default 数据库中字段的默认值
primary_key 数据库中字段是否为主键
db_index 数据库中字段是否可以建立索引
unique 数据库中字段是否可以建立唯一索引 class Meta:
### 联合唯一索引
unique_together=[
('b', 'g')
] #### 联合索引
index_together = [
('b', 'g')
]
五、Django只在admin中生效的数据类型
- EmailField(CharField):
字符串类型对应信息是不是邮箱格式进行验证 - IPAddressField(Field):
字符串类型,Django Admin以及ModelForm中提供验证 IPV4 机制 - GenericIPAddressField(Field):
字符串类型,Django Admin以及ModelForm中提供验证 Ipv4和Ipv6- 参数:
- protocol:用于指定Ipv4或Ipv6, 'both',"ipv4","ipv6"
- unpack_ipv4: 如如果指定为True,则输入::ffff:192.0.2.1时候,可解析为192.0.2.1,开启刺功能,需要protocol="both"
- 参数:
- URLField(CharField):
字符串类型,Django Admin以及ModelForm中提供验证 URL - SlugField(CharField):
字符串类型,Django Admin以及ModelForm中提供验证支持 字母、数字、下划线、连接符(减号) - CommaSeparatedIntegerField(CharField):
字符串类型,格式必须为逗号分割的数字 - UUIDField(Field):
字符串类型,Django Admin以及ModelForm中提供对UUID格式的验证 - FilePathField(Field):
字符串,Django Admin以及ModelForm中提供读取文件夹下文件的功能- 参数:
- path:文件路径
- match=None:正则匹配
- recursive=False:递归下面的文件夹
- allow_files=True:允许文件
- allow_folders=False:允许文件夹
- 参数:
- ImageField(FileField):
字符串类型路径保存在数据库,文件上传到指定目录- 参数:
- upload_to = "" : 上传文件的保存路径
- storage = None:存储组件,默认django.core.files.storage.FileSystemStorage
- ImageField(FileField):上传图片的高度保存的数据库字段名(字符串)
- height_field=None:上传图片的宽度保存的数据库字段名(字符串)
- 参数:
六、Django只在admin中生效的属性
verbose_name:Admin中显示的字段名称
blank:Admin中是否允许用户输入为空
editable:Admin中是否可以编辑
help_text:Admin中该字段的提示信息
choices:Admin中显示选择框的内容,用不变动的数据放在内存中从而避免跨表操作
- 如:gf = models.IntegerField(choices=[(0, '何穗'),(1, '大表姐'),],default=1)
error_messages: 自定义错误信息(字典类型),从而定制想要显示的错误信息;
- from django.core.validators import RegexValidator
from django.core.validators import EmailValidator,URLValidator,DecimalValidator,
MaxLengthValidator,MinLengthValidator,MaxValueValidator,MinValueValidator
如:
test = models.CharField(
max_length=32,
error_messages={
'c1': '优先错信息1',
'c2': '优先错信息2',
'c3': '优先错信息3',
},
validators=[
RegexValidator(regex='root_\d+', message='错误了', code='c1'),
RegexValidator(regex='root_112233\d+', message='又错误了', code='c2'),
EmailValidator(message='又错误了', code='c3'), ]
)
- from django.core.validators import RegexValidator
七、Django自带分页
1.导入模块
from django.core.paginator import Paginator
2.读取信息
userlist = models.UserInfo.objects.all()
3.生成painantor对象
生成painantor对象
paginator = Paginator(userlist, 10) #对象,每页多少条数据
painantor的属性与方法
- 属性
- object_list:返回所有页对象的的列表
- per_page: 每页显示条目数量
- count:数据总个数
- num_pages:总页数
- page_range:总页数的索引范围,如: (1,10),(1,200)
- 方法
- page(第几页):page对象
4.生成page对象
生成page对象
page_1 = paginator.page(1) #第一页的信息
page的属性和方法
- 属性
- object_list:返回当前页对象的的列表
- number:返回当前页是第几页,从1开始
- paginator:当前页对应的paginator对象
- 方法
- has_next(): 是否有下一页,有就返回Ture
- next_page_numbe()r:返回值下一页页码
- has_previous():是否有上一页,有就返回Ture
- previous_page_number():返回值上一页页码
【注】
用orm获得表里面信息的时候,它是个列表,可以利用列表的切片技术来进行内容选取而达到分页的效果
Python Web(二)的更多相关文章
- python web框架——扩展Django&tornado
一 Django自定义分页 目的:自定义分页功能,并把它写成模块(注意其中涉及到的python基础知识) models.py文件 # Create your models here. class Us ...
- windows下python web开发环境的搭建
windows下python web开发环境: python2.7,django1.5.1,eclipse4.3.2,pydev3.4.1 一. python环境安装 https://www.pyth ...
- 我的第一个python web开发框架(1)——前言
由于之前经验不是很丰富,写的C#系统太过复杂,所以一直想重写,但学的越多越觉得自己懂的越少,越觉的底气不足.所以一直不敢动手,在内心深处对自己讲,要静下心来认真学习,继续沉淀沉淀.这两年多以来找各种机 ...
- python web框架之Tornado
说Tornado之前分享几个前端不错的网站: -- Bootstrap http://www.bootcss.com/ -- Font Awesome http://fontawesome.io/ - ...
- Python Web框架
本节对Python Web框架学习 一.MTVModel: 存放所有数据库相关文件Template:模板文件,存放html文件View: 业务处理,即函数文件 二.MVCmodel: 存放数据库相关文 ...
- Python web(Django)连接Sql server
(开开心心每一天~ ---虫瘾师) Python Web(Django) 与SQL SERVRE的连接----Come QQ群:607021567(里面有很多开源代码和资料,并且python的游戏也有 ...
- Python Web(Django)与SQL SERVER的连接处理
(开开心心每一天~ ---虫瘾师) Python Web(Django) 与SQL SERVRE的连接----Come QQ群:607021567(里面有很多开源代码和资料,并且python的游戏也有 ...
- 我的第一个python web开发框架(41)——总结
我的第一个python web开发框架系列博文从17年6.7月份开始写(存了近十章稿留到9月份才开始发布),到今天结束,一年多时间,想想真不容易啊. 整个过程断断续续,中间有段时间由于工作繁忙停了好长 ...
- 浅谈Python web框架
一.Python web框架 Web Framework,Ruby的世界Rails一统江湖,而Python则是一个百花齐放的世界,各种micro-framework.framework不可胜数,不完全 ...
随机推荐
- 【每天一题】LeetCode 121. 买卖股票的最佳时机
开源地址:点击该链接 题目描述 * https://leetcode-cn.com/problems/best-time-to-buy-and-sell-stock * 题目描述: * 给定一个数组, ...
- ASP.NET4.0中JavaScript脚本调用Web Service 方法
环境:VS2019 .net 4.0 framework 根据教材使用ScriptManager在JavaScript中调用Web service 时,失败.现将过程和解决方法记录如下: 1.定义W ...
- Android开发模版代码(4)——状态栏设置
下面的代码是基于开源项目SystemBarTint,我们需要添加其依赖 compile 'com.readystatesoftware.systembartint:systembartint:1.0. ...
- everspin自旋转矩MRAM技术
MRAM的主体结构由三层结构的MTJ构成:自由层(free layer),固定层和氧化层.自由层与固定层的材料分别是CoFeB和MgO.MRAM 是一种非易失性的磁性随机存储器.它拥有静态随机存储器( ...
- React-Native踩坑记录二
1.Image组件的borderRadius画圆有平台兼容性问题,在IOS下会失效 解决方法有几种 (1)在外面包裹一层View,对View组件使用borderRadius就可以了,这是我的做法 (2 ...
- 提升代码幸福度,五个技巧减少js开发中的if else语句
壹 ❀ 引 在JavaScript开发中,条件判断语句的使用频率是极高的,而对于条件判断简单易读的if else应该都是大家的首选.可是代码写的久了,我们总是希望自己的代码看着能更为简洁规范(逼格更 ...
- Java生鲜电商平台-深入理解微服务SpringCloud各个组件的关联与架构
Java生鲜电商平台-深入理解微服务SpringCloud各个组件的关联与架构 概述 毫无疑问,Spring Cloud是目前微服务架构领域的翘楚,无数的书籍博客都在讲解这个技术.不过大多数讲解还停留 ...
- Java 基础复习 基础数据类型与包装器类型
Java 基础 基础数据类型与包装器类型 基础数据类型 java 中包含哪些基础数据类型,默认值分别是多少? 基础数据类型 byte short int long double float char ...
- laravel大量填充项目测试数据的正确方法
项目开发时,一般都会有到项目测试数据的准备操作,以前都是基于PHP代码自主编写sql语句,然后循环的插入到数据库中里面,当当我们接触过laravel数据库后,就可以很方便的完成项目的测试数据准备. 但 ...
- Angular(05)- 组件知识点脑图
点击左键 => 拖拽图片 => 新标签页查看图片 => 放大拖拽查阅