# encoding=utf-8
from app.models import Student
from flask import g import re
from flask.ext.wtf import Form
from wtforms import StringField, RadioField, PasswordField, TextAreaField, BooleanField, DateField, ValidationError, \
IntegerField
from wtforms.validators import DataRequired, Length, Regexp, Email, EqualTo
from wtforms.widgets import ListWidget, HTMLString class BSListWidget(ListWidget):
def __call__(self, field, **kwargs):
kwargs.setdefault('id', field.id)
html = ""
for subfield in field:
html += u'<label class="radio-inline"> %s%s </label>' % (subfield(), subfield.label.text)
return HTMLString(html) class Fields(object):
notnull = u'该项输入不能为空' def get_len_str(min=None, max=None):
if min and not max:
return u"该项输入的最小长度必须是%d" % min
elif max and not min:
return u"该项输入的最大长度必须是%d" % max
else:
return u'该输入的长度必须大于%d,小于%d' % (min, max) username = StringField(label=u'请输入您的用户名',
validators=[DataRequired(message=notnull),
Length(min=0, max=15, message=get_len_str(0, 16)),
]) password = PasswordField(label=u'请输入密码', description=u'请输入密码',
validators=[DataRequired(message=notnull),
Length(min=0, max=60, message=get_len_str(min=0, max=61)),
])
confirm_password = PasswordField(label=u'请确认密码',
description=u'请确认密码', validators=[DataRequired(message=notnull),
Length(min=5, max=60, message=get_len_str(min=4, max=61)),
EqualTo(u'confirm_password', message=u'两次输入的密码不一致'), ]
)
student_amount = StringField(label=u'请输入您指导的学生数量',
validators=[Regexp(re.compile(r"\d"))]) is_active = RadioField(label=u'是否激活账户',
coerce=int,
choices=[(0, u'否'), (1, u'是')],
default=0,
widget=BSListWidget()) notice = TextAreaField(label=u'请填写对学生的通知') attachment = StringField(label=u'添加附加',
validators=[Length(min=0, max=32, message=get_len_str(min=0, max=33))], ) is_comment_teacher = RadioField(label=u'是否有评价功能',
coerce=int,
choices=[(0, u'否'), (1, u'是')],
default=0,
widget=BSListWidget()) student_name = StringField(label=u'请输入您的姓名',
description='',
validators=[DataRequired(message=notnull),
Length(min=0, max=15, message=get_len_str(0, 16)),
]) sex = RadioField(label=u'您的性别',
coerce=int,
choices=[(0, u'男'), (1, u'女')],
default=0,
widget=BSListWidget()) user_type = RadioField(label=u'您是',
coerce=str,
choices=[(u'student', u'学生'), (u'teacher', u'老师'), (u'admin', u'管理员')],
default=u'student',
widget=BSListWidget()) mark = StringField(label=u'您的分数',
default=0,
validators=[DataRequired(message=notnull),
Length(min=0, max=100, message=get_len_str(0, 101)),
])
comment = TextAreaField(label=u'请填写您对学生的评语',
validators=[
Length(min=0, max=128, message=get_len_str(0, 129)),
]) title = StringField(label=u'请填写毕业设计的题目',
validators=[
Length(min=0, max=128, message=get_len_str(0, 129)),
])
description = TextAreaField(label=u'请填写毕业设计的描述') task_start_date = DateField(label=u'开始时间')
task_end_date = DateField(label=u'结束时间') comment_start_date = DateField(label=u'开始时间')
comment_end_date = DateField(label=u'结束时间') class LoginForm(Form):
username = Fields.username
password = Fields.password user_type = Fields.user_type remember_me = BooleanField(label=u'记住我', default=u'y') errors = {} def validate_fields(self):
status = True
status = status and self.username.validate(self)
status = status and self.username.validate(self)
self.password.validate() # def validate(self):
self._fields
self.validate_on_submit()
return self.username.validate(self) # def validate_username(self, field):
# user = Student.get_user(field.data)
# if not user:
# print 'not user'
# self.errors['username'] = u'用户名不存在'
# raise ValidationError(message=u'该用户名已被注册')
# else:
# print 'user'
# return True #
# def validate_password(self,field):
# if g.user:
# if field.data != g.user.username:
# field.errors.append(message=u'用户密码不正确')
# return False
#
# def validate_user_type(self, field):
# print field.data
#
# def validate_remember_me(self,field):
# if field.data:
# print field.data class StuInfo(Form):
username = Fields.username
student_name = Fields.student_name
sex = Fields.sex
attachment = Fields.attachment
mark = Fields.mark
comment = Fields.comment class BaseForm(object):
def __init__(self, form):
self.username = Field(label=u'用户名', type='text', validators={'min_length': 5}) for field_name, data in form.items():
getattr(self, field_name).data = data def validate(self):
status = True
for field_name in self.__dict__:
status = status and getattr(self, field_name).validate()
return status class Field(object):
def __init__(self, label=None, type='text', validators={}, description=None, data=''):
self.data = data
self.label = label
self.type = type
self.validators = validators
self.description = description def validate(self):
status = True
for method_name, param in self.validators.items():
print method_name, param
status = status and getattr(self, method_name)(param)
return status def is_null(self, status):
if status:
return True
if not self.data:
return False
if hasattr(self.data, 'replace') and len(self.data.replace(' ', '')) > 0:
return False
if len(self.data) == 0:
return False
return True def min_length(self, min=-1):
if not self.is_null(False) and len(self.data) < min:
return False
return True def max_length(self, max):
if not self.is_null(False) and len(self.data) > max:
return False
return True def min(self, min):
try:
if int(self.data) < min:
return False
return True
except Exception, e:
print e
return False def max(self, max):
try:
if int(self.data) > max:
return False
return True
except Exception, e:
print e
return False def equal_to(self, data):
if self.data != data:
return False
return True def select_from(self, *args):
if self.data not in args:
return False
return True if __name__ == '__main__':
b = BaseForm({'username': 'o'})
print b.validate()
print 'ok'

 

python实现简单表单校验框架的更多相关文章

  1. Spring MVC 文件上传、Restful、表单校验框架

    目录 文件上传 Restful Restful 简介 Rest 行为常用约定方式 Restful开发入门 表单校验框架 表单校验框架介绍 快速入门 多规则校验 嵌套校验 分组校验 综合案例 实用校验范 ...

  2. 利用jquery.validate以及bootstrap的tooltip开发气泡式的表单校验组件

    表单校验是页面开发中非常常见的一类需求,相信每个前端开发人员都有这方面的经验.网上有很多成熟的表单校验框架,虽然按照它们默认的设计,用起来没有多大的问题,但是在实际工作中,表单校验有可能有比较复杂的个 ...

  3. Vue.js + Nuxt.js 项目中使用 Vee-validate 表单校验

    vee-validate 是为 Vue.js 量身打造的表单校验框架,允许您校验输入的内容并显示对应的错误提示信息.它内置了很多常见的校验规则,可以组合使用多种校验规则,大部分场景只需要配置就能实现开 ...

  4. Vee-validate 父组件获取子组件表单校验结果

    vee-validate 是为 Vue.js 量身打造的表单校验框架,允许您校验输入的内容并显示对应的错误提示信息.它内置了很多常见的校验规则,可以组合使用多种校验规则,大部分场景只需要配置就能实现开 ...

  5. JEECG 3.7.8 新版表单校验提示风格使用&升级方法(validform 新风格漂亮,布局简单)

    JEECG 表单校验采用的是validform,默认的校验提示需要占用页面布局,提示效果较传统.jeecg这个自定义的校验提示风格,不占用页面布局,提示效果也更美观,简单易用,让表单看起来更漂亮!!! ...

  6. 简单好用的表单校验插件——jQuery Validate基本使用方法总结

    jquery validate当前最新版本是1.17.0,下载链接是:https://github.com/jquery-validation/jquery-validation/releases/t ...

  7. easyui 进阶之表单校验、自定义校验

    前言 easyui是一种基于jQuery的用户界面插件集合,它为创建现代化,互动,JavaScript应用程序,提供必要的功能,完美支持HTML5网页的完整框架,节省网页开发的时间和规模.非常的简单易 ...

  8. js--吐血总结最近遇到的变态表单校验---element+原生+jq+easyUI(前端职业生涯见过的最烦的校验)

    最近写了无数各种形式的表单,记录下奇奇怪怪的校验规则~ 一:首先是element自带的rules校验规则: element作为常用框架,自带rules属性简单易懂,官方文档一目了然,不再赘述,应付常用 ...

  9. AngularJS 1.2.x 学习笔记(表单校验篇)

    https://my.oschina.net/cokolin/blog/526911 摘要: 本文首发于 blog.csdn.net/vipshop_ebs/article/details/39472 ...

随机推荐

  1. web项目配置webAppRootKey 获得根目录 .

    log4j和web.xml配置webAppRootKey 的问题 1 在web.xml配置 <context-param>  <param-name>webAppRootKey ...

  2. php的一些小笔记--字符串

    字符串: 转换ASCII函数: ord($tring) 返回ASCII,chr($ASCII)返回相应的字符 把字符串切割成数据的函数: chunk_split($string,$len) chunk ...

  3. PHP判断访客是否移动端浏览器访问

    今天要给大家分享一段PHP代码,该代码的功能是用来判断访客是否移动端浏览器访问,该功能的实现思路是通过HTTP_X_WAP_PROFILE. HTTP_VIA.HTTP_USER_AGENT等信息来判 ...

  4. 快速制作规则及获取规则提取器API

    1. 引言 前面文章的测试案例都用到了集搜客Gooseeker提供的规则提取器,在网页抓取工作中,调试正则表达式或者XPath都是特别繁琐的,耗时耗力,工作枯燥,如果有一个工具可以快速生成规则,而且可 ...

  5. 凸包(hd1392)

    Surround the Trees Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

  6. iOS Layer CABasicAnimation

    @import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/c ...

  7. opencv学习之旅_绘制跟踪轨迹

    如何将运动物体的轨迹画出来 我的想法是先:用CAMSHIFT跟踪物体,这个函数会返回一个track_box,将box的中心提取出来,然后以这个中心在另外的图像上画出来,然后将这张图像处理,提取轮廓,提 ...

  8. 删除IE缓存中指定的文件

    DeleteUrlCacheEntry 1.文件单元:WinInt VC声明 BOOL DeleteUrlCacheEntry ( LPCTSTR lpszUrlName); 函数功能 删除Cache ...

  9. Android EditText setOnClickListener事件 只有获取焦点才能响应 采用setOnTouchListener解决

    最近在学习Android开发,在编写程序的过程中,发现EditText setOnClickListener事件响应中,只有获取焦点的时候才会响应, 如当焦点在别的控件上时,只能先点击获取焦点,第二次 ...

  10. 【总结】OJ练习,进行的一些编程语言方面总结

    1.STL vector只有四个构造函数 ) explicit vector (const allocator_type& alloc = allocator_type()); fill () ...