时间:2021-05-22
app01/models.py:
from django.db import models class UserInfo(models.Model): username = models.CharField(max_length=16) password = models.CharField(max_length=16) mobile = models.CharField(max_length=11) class City(models.Model): name = models.CharField(max_length=16, null=False, unique=True)往 City 表中添加数据
这时候需要重启服务才能在页面上显示这些内容
也就是说每次数据库中的内容更新,都需要重启服务才能显示出来
可以通过重写父类中的 __init__ 方法来解决
views.py:
from django.shortcuts import render, HttpResponsefrom app01 import models from django import formsfrom django.forms import widgetsfrom django.core.validators import RegexValidatorfrom django.core.exceptions import ValidationError class RegForm(forms.Form): username = forms.CharField( min_length=5, label="用户名", error_messages={ "min_length": "用户名不能小于5位!", "required": "该字段不能为空" }, widget=widgets.TextInput(attrs={"class": "form-control"}) ) password = forms.CharField( min_length=6, label="密码", error_messages={ "min_length": "密码不能少于6位!", "required": "该字段不能为空" }, widget=widgets.PasswordInput(attrs={"class": "form-control"}, render_value=True) ) re_password = forms.CharField( min_length=6, label="确认密码", error_messages={ "required": "该字段不能为空" }, widget=widgets.PasswordInput(attrs={"class": "form-control"}, render_value=True) ) mobile = forms.CharField( label="手机号", # 自定义正则匹配规则 validators=[ RegexValidator(r'^[0-9]+$', "手机号必须是数字"), # 判断手机号是否为数字 RegexValidator(r'^1[3-9][0-9]{9}$', "手机格式有误") # 判断手机号是否为 1 和 3-9 开头的十一位数 ], error_messages={ "required": "该字段不能为空", }, widget=widgets.TextInput(attrs={"class": "form-control"}) ) city = forms.ChoiceField( choices=models.City.objects.values_list("id", "name"), label="城市", initial=2, widget=widgets.Select() ) # 重写父类的 __init__ 方法 def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) self.fields['city'].widget.choices = models.City.objects.values_list("id", "name") # 判断用户名信息 def clean_username(self): value = self.cleaned_data.get("username") if "admin" in value: raise ValidationError("用户名不能含有敏感信息") # 重写父类的 clean 方法 def clean(self): password = self.cleaned_data.get("password") re_password = self.cleaned_data.get("re_password") if re_password != password: self.add_error("password", ValidationError("两次密码不一致")) self.add_error("re_password", ValidationError("两次密码不一致")) raise ValidationError("两次密码不一致") return self.cleaned_data def reg2(request): form_obj = RegForm() # GET 请求 if request.method == "POST": form_obj = RegForm(request.POST) # 让 form 来帮我们进行校验 if form_obj.is_valid(): # 如果通过校验 # 所有经过校验的数据都保存在 form_obj.cleaned_data print(form_obj.cleaned_data) models.UserInfo.objects.create(**form_obj.cleaned_data) return HttpResponse("注册成功") return render(request, "reg2.html", {"form_obj": form_obj})运行结果:
以上这篇Python Django form 组件动态从数据库取choices数据实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Django的Field类中方法有:to_python()#把数据库数据转成python数据from_db_value()#把数据库数据转成python数据ge
Django的数据库层从Python代码生成SQLschemas—但是对于遗留数据库,你已经拥有SQLschemas.这种情况,你需要为已经存在的数据表创建mo
此文是在django框架下编写,从数据库中获取数据使用的是django-orm用python导出数据到excel,简单到爆!(普通的excel格式)安装xlwt
目标:从plc采集数据到数据库,利用echart绘制实时动态曲线。1思路-django定时执行任务,将数据推送到echart。-前端定时读取后端数据,并显示到e
1.COMMIT_FORM和COMMIT都对form和数据库进行提交。针对form上面的数据变动提交到后台数据库,同时数据库提交数据。2.DO_KEY('COM