【Django】ModelForm
ModelForm
1.Model与Form内容回顾
- Model
- - 数据库操作
- - 验证
- class A(MOdel):
- user =
- email =
- pwd =
- Form
- - class LoginForm(Form):
- email = fields.EmailField()
- user =
- pwd =
- - is_valid -> 每一个字段进行正则(字段内置正则)+clean_字段 -> clean(__all__) -> _post_clean
- - cleand_data
- - error
2.ModelForm的作用
Django中内置了Form和Model两个类,有时候页面的表单form类与Model类是一一对应,因此分别定义Form类和Model类会比较麻烦,最简单的方式就是通过Model来生成一个Form类,Django内置的ModelForm就是为此而生的.
ModelForm作为model和form的结合体,所以有以下功能:
- 验证
- 数据库操作
3.创建models.py
- from django.db import models
- class UserType(models.Model):
- caption = models.CharField(max_length=32)
- class UserGroup(models.Model):
- name = models.CharField(max_length=32)
- class UserInfo(models.Model):
- username = models.CharField(verbose_name='用户',max_length=32)
- email = models.EmailField(verbose_name='邮箱')
- user_type = models.ForeignKey(to='UserType',to_field='id')
- u2g = models.ManyToManyField(UserGroup)
app01/models.py
4.创建ModelForm,获取models.py字段数据
- from django.shortcuts import render,HttpResponse,redirect
- from django import forms
- from app01 import models
- class UserInfoModelForm(forms.ModelForm): #ModelForm直接用models字段
- class Meta:
- model = models.UserInfo #表示去models.py文件中UserInfo类获取字段
- fields = '__all__' #获取所有字段
- # fields = ['username','email','user_type'] #获取指定的字段
- # exclude = ['username'] #获取username以外其他字段
- def index(request):
- if request.method == "GET":
- obj = UserInfoModelForm()
- return render(request,"index.html",{'obj':obj})
- elif request.method == "POST":
- obj = UserInfoModelForm(request.POST)
- print(obj.is_valid()) # 这是方法,别忘记了加括号
- print(obj.cleaned_data)
- print(obj.errors)
- return render(request,"index.html",{'obj':obj})
app01/views.py
5、ModelForm组件
- ModelForm
- a. class Meta:
- model, # 对应Model的
- fields=None, # 字段
- exclude=None, # 排除字段
- labels=None, # 提示信息
- help_texts=None, # 帮助提示信息
- widgets=None, # 自定义插件
- error_messages=None, # 自定义错误信息(整体错误信息from django.core.exceptions import NON_FIELD_ERRORS)
- field_classes=None # 自定义字段类 (也可以自定义字段)
- localized_fields=('birth_date',) # 本地化,如:根据不同时区显示数据
- 如:
- 数据库中
- 2016-12-27 04:10:57
- setting中的配置
- TIME_ZONE = 'Asia/Shanghai'
- USE_TZ = True
- 则显示:
- 2016-12-27 12:10:57
- b. 验证执行过程
- is_valid -> full_clean -> 钩子 -> 整体错误
- c. 字典字段验证
- def clean_字段名(self):
- # 可以抛出异常
- # from django.core.exceptions import ValidationError
- return "新值"
- d. 用于验证
- model_form_obj = XXOOModelForm()
- model_form_obj.is_valid()
- model_form_obj.errors.as_json()
- model_form_obj.clean()
- model_form_obj.cleaned_data
- e. 用于创建
- model_form_obj = XXOOModelForm(request.POST)
- #### 页面显示,并提交 #####
- # 默认保存多对多
- obj = form.save(commit=True)
- # 不做任何操作,内部定义 save_m2m(用于保存多对多)
- obj = form.save(commit=False)
- obj.save() # 保存单表信息
- obj.save_m2m() # 保存关联多对多信息
- f. 用于更新和初始化
- obj = model.tb.objects.get(id=1)
- model_form_obj = XXOOModelForm(request.POST,instance=obj)
- ...
- PS: 单纯初始化
- model_form_obj = XXOOModelForm(initial={...})ModelForm
- a. class Meta:
- model, # 对应Model的
- fields=None, # 字段
- exclude=None, # 排除字段
- labels=None, # 提示信息
- help_texts=None, # 帮助提示信息
- widgets=None, # 自定义插件
- error_messages=None, # 自定义错误信息(整体错误信息from django.core.exceptions import NON_FIELD_ERRORS)
- field_classes=None # 自定义字段类 (也可以自定义字段)
- localized_fields=('birth_date',) # 本地化,如:根据不同时区显示数据
- 如:
- 数据库中
- 2016-12-27 04:10:57
- setting中的配置
- TIME_ZONE = 'Asia/Shanghai'
- USE_TZ = True
- 则显示:
- 2016-12-27 12:10:57
- b. 验证执行过程
- is_valid -> full_clean -> 钩子 -> 整体错误
- c. 字典字段验证
- def clean_字段名(self):
- # 可以抛出异常
- # from django.core.exceptions import ValidationError
- return "新值"
- d. 用于验证
- model_form_obj = XXOOModelForm()
- model_form_obj.is_valid()
- model_form_obj.errors.as_json()
- model_form_obj.clean()
- model_form_obj.cleaned_data
- e. 用于创建
- model_form_obj = XXOOModelForm(request.POST)
- #### 页面显示,并提交 #####
- # 默认保存多对多
- obj = form.save(commit=True)
- # 不做任何操作,内部定义 save_m2m(用于保存多对多)
- obj = form.save(commit=False)
- obj.save() # 保存单表信息
- obj.save_m2m() # 保存关联多对多信息
- f. 用于更新和初始化
- obj = model.tb.objects.get(id=1)
- model_form_obj = XXOOModelForm(request.POST,instance=obj)
- ...
- PS: 单纯初始化
- model_form_obj = XXOOModelForm(initial={...})
注意:导入模块名(fields、widgets)和字段名重复,所以导入时要起个别名。
- from django.forms import fields as Ffields
- from django.forms import widgets as Fwidgets
- 关于Meta的使用方法:
- class Meta:
- model = models.UserInfo
- fields = '__all__'
- # fields = ['username','email']
- # exclude = ['username']
- labels = {
- 'username': '用户名',
- 'email': '邮箱',
- 'user_type':'一对多',
- 'u2g': '多对多',
- }
- help_texts = {
- 'username': '...'
- }
- widgets = {
- 'username': Fwidgets.Textarea(attrs={'class': 'c1'})
- }
- error_messages = {
- '__all__':{ # 整体错误信息
- },
- 'email': {
- 'required': '邮箱不能为空',
- 'invalid': '邮箱格式错误..',
- }
- }
- field_classes = { # 定义字段的类是什么
- # 'email': Ffields.URLField # 这里只能填类,加上括号就是对象了。
- }
- # localized_fields=('ctime',) # 哪些字段做本地化
6.ModelForm 数据库操作——创建数据save
- def index(request):
- if request.method == "GET":
- obj = UserInfoModelForm()
- return render(request,'index.html',{'obj': obj})
- elif request.method == "POST":
- obj = UserInfoModelForm(request.POST)
- if obj.is_valid():
- obj.save() # 等价以下三句
- # instance = obj.save(False)
- # instance.save()
- # obj.save_m2m()
- return render(request,'index.html',{'obj': obj})
app01/views.py #对index函数进行修改及可
- from django.conf.urls import url
- from django.contrib import admin
- from app01 import views
- urlpatterns = [
- url(r'^admin/', admin.site.urls),
- url(r'^index/', views.index),
- ]
project/urls.py
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- </head>
- <body>
- <form action="/index/" method="POST">
- {% csrf_token %}
- {{ obj.as_p }}
- <input type="submit" value="提交"/>
- </form>
- </body>
- </html>
templates/index.html
7.ModelForm 数据库操作——修改数据
- urlpatterns = [
- url(r'^user_list/', views.user_list), #新增
- url(r'^edit-(\d+)/', views.user_edit), #新增
- ]
project/urls.py
- def user_list(request):
- li = models.UserInfo.objects.all().select_related('user_type')#跨表取数据
- return render(request,'user_list.html',{'li':li})
- def user_edit(request,nid):
- #获取当前ID对象的用户信息
- #显示用户已经存在数据
- if request.method == 'GET':
- user_obj = models.UserInfo.objects.filter(id=nid).first()
- mf = UserInfoModelForm(instance=user_obj) #instance=user_obj,把默认数据传递进去,显示经存在数据
- return render(request, 'user_edit.html',{'mf':mf,nid:'nid'})
- elif request.method == 'POST':
- user_obj = models.UserInfo.objects.filter(id=nid).first()
- mf = UserInfoModelForm(request.POST,instance=user_obj) # 指定给谁做修改
- if mf.is_valid():
- mf.save()
- else:
- print(mf.errors.as_json)
- return render(request, 'user_edit.html',{'mf':mf,nid:'nid'})
app01/views.py
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- </head>
- <body>
- <ul>
- {% for k in li %}
- <li>{{ k.username }}-{{ k.user_type.caption }}-|<a href="/edit-{{ k.id }}">编辑</a></li>
- {% endfor %}
- </ul>
- </body>
- </html>
templates/user_list.html
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>Title</title>
- </head>
- <body>
- <form action="/edit-{{ nid }}/" method="post">
- {% csrf_token %}
- {{ mf.as_p }}
- <input type="submit" value="提交"/>
- </form>
- </body>
- </html>
templates/user_edit.html
【Django】ModelForm的更多相关文章
- 【Django】--ModelForm组件
ModelForm a.class Meta: model,#对应Model的 fields=None,#字段 exclude=None,#排除字段 labels=None,#提示信息 help_te ...
- 【Django】ORM操作#1
目录 一.介绍 概念 由来 优势 劣势 总结 二.Django中的ORM Django项目使用MySQL Model 快速入门 1. AutoField 2. IntegerField 3. Char ...
- 【Django】 初步学习
这个系列(或者成不了一个系列..)预计会全程参考Vamei様的Django系列,膜一发.说句题外话,其实更加崇拜像Vamei那样的能够玩转生活.各个领域都能取得不小成就的人. [Django] ■ 概 ...
- 【Django】ORM操作#2
目录 必知必会的13条查询方法 单表查询之神奇的双下划线 一对多 ForeignKey 多对多 ManyToManyField 在Python脚本中调用Django环境 Django终端打印SQL语句 ...
- 【Django】--Model字段
参考地址:http://www.cnblogs.com/wupeiqi/articles/6216618.html 所有字段 AutoField(Field) --int自增列,必须填入参数prima ...
- 【Django】Web应用开发经由
[Django开发经由] 本来以为看完网上的入门教程之后就可以看书详细学习一下,没想到手头上的这本书也讲得不是太详细..无奈,不过好在这本书从无到有建立一个网站的流程还算可以,就以这个角度简单记录一下 ...
- Python开发【Django】:Form组件
Form组件 Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 创建Form类时,主要涉及到 [ ...
- 【django】form
form 组件组要功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 1.创建Form类时,主要涉及到 [字段] 和 [插件],字段用于 ...
- 【Django】--Form组件
Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 例子: 1.创建Form类 from djan ...
随机推荐
- unity之初级
- Leetcode之二分法专题-374. 猜数字大小(374. Guess Number Higher or Lower)
Leetcode之二分法专题-374. 猜数字大小(374. Guess Number Higher or Lower) 我们正在玩一个猜数字游戏. 游戏规则如下:我从 1 到 n 选择一个数字. 你 ...
- Anaconda简单使用手册
安装部分 准备工作 下载各平台对应的安装包,各平台安装包下载链接如下: Windows macOs Linux 安装过程 安装过程在此不给出具体过程,可参照官方给出教程,各平台对应教程如下: Wind ...
- NLP(二十) 利用词向量实现高维词在二维空间的可视化
准备 Alice in Wonderland数据集可用于单词抽取,结合稠密网络可实现其单词的可视化,这与编码器-解码器架构类似. 代码 from __future__ import print_fun ...
- bzoj 1146 网络管理Network (CDQ 整体二分 + 树刨)
题目传送门 题意:求树上路径可修改的第k大值是多少. 题解:CDQ整体二分+树刨. 每一个位置上的数都会有一段持续区间 根据CDQ拆的思维,可以将这个数拆成出现的时间点和消失的时间点. 然后通过整体二 ...
- HihoCoder - 1617 方格取数
HihoCoder - 1617 (从群主那里借鉴来的, 群主好强啊) 题意:中文题不解释... 题解: dp[X][i][j] 代表的是X是坐标之和 第一个人 走到位置 dp[i][x-i] 第二个 ...
- CF 988E Divisibility by 25 思维 第十二
Divisibility by 25 time limit per test 1 second memory limit per test 256 megabytes input standard i ...
- yzoj2057 x 题解
题意:给出一个集合,要求把这个集合分成两部分,使得一个集合中的任一元素都与另一个集合的全部元素都两两互质 暴力 枚举每个元素O(n^2)再暴力判gcd=1,如果非1就放入不同集合内,用并查集维护联通块 ...
- Mysql高手系列 - 第7篇:玩转select条件查询,避免踩坑
这是Mysql系列第7篇. 环境:mysql5.7.25,cmd命令中进行演示. 电商中:我们想查看某个用户所有的订单,或者想查看某个用户在某个时间段内所有的订单,此时我们需要对订单表数据进行筛选,按 ...
- 微服务时代之自定义archetype(模板/骨架/脚手架)
1. 场景描述 (1)随着微服务越来越常见,一个大的项目会被拆分成多个小的微服务,jar包以及jar之间的版本冲突问题,变得越来越常见,如何保持整体微服务群jar及版本统一,也变成更加重要了,mave ...