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, HttpResponse from app01 import models from django import forms from django.forms import widgets from django.core.validators import RegexValidator from 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数据实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
我需要在spring批处理作业的步骤中动态设置块大小,该步骤存储在数据库中,即需要从数据库中获取块大小并将其设置到bean中。 我的问题是: 从ID='some_id_param_value'的SOME_TABLE_NAME选择CHUNK_SIZE 在这里,的值将来自作业参数,该参数是通过与请求一起传递到 它无法从访问“chunk”键值,因此引发。是否需要以某种方式对其进行升级,以便可以在step
我已经花了几个小时阅读产品分支中的0和1。请在Firebase数据库有经验的人帮助我:(
问题内容: 在我的Django项目中,我对第三方应用程序具有依赖性,该第三方应用程序在具有已知模式的各个目录中生成SQLite缓存文件。 我想使用Django模型来访问这些数据库,但是显然我不能使用静态DATABASES设置。 如何在任意路径上动态打开SQLite数据库? 编辑 正如Byron Ruth所指出的,解决方案是将django.db.connections结合使用usingQuerySe
我试图从Firebase数据库中读取数据,我已经到处阅读和查找,但我已经走到了死胡同。 这就是我所做的一切。 依赖项: 实现'com.google.firebase: Firebase存储: 9.2.1' 实现'com。谷歌。firebase:firebase数据库:9.2。1' 实现'com。谷歌。firebase:firebase授权:9.2。1' 实现'com。谷歌。火基:火基核心:9.2。
本文向大家介绍node.js从数据库获取数据,包括了node.js从数据库获取数据的使用技巧和注意事项,需要的朋友参考一下 本文需要用node.js做一个从Sqlserver获取数据并显示到页面上的小功能,下面就为大家分享: app.js: 接下来就直接在页面中使用get方式请求即可,当然post方式也是类似原理。 还有我发现textarea控件在改变其text和html属性的时候,value还保
问题内容: 我对数据库及其在CRUD操作之外提供的功能不是很熟悉。 我的研究使我 引人注目 。基本上,触发器似乎提供了这种类型的功能: (来自维基百科) 通常,有三个触发事件导致触发器“触发”: INSERT事件(将新记录插入数据库中)。 UPDATE事件(因为记录正在更改)。 DELETE事件(因为一条记录正在被删除)。 我的问题是:当使用某种触发语义对记录进行更新/删除/插入时,数据库是否可以