36.wtfrom与peewee综合实操——wtfrom模板渲染、wtfrom数据验证、peewee保存数据

本文介绍如何使用Tornado Web框架结合WTForms实现表单渲染、数据验证及Peewee ORM进行数据持久化的全过程。从搭建环境到实现具体功能,包括表单数据的前后端交互、字段验证规则设定及数据库操作等。
摘要由CSDN通过智能技术生成

1.概述

  1. 通过wtform渲染模板
  2. 通过wtform验证表单数据
  3. 通过peewee保存数据

2.渲染模板

方法概述可以查看第35节内容

2.1后端

from tornado.web import Application, RequestHandler
from tornado.ioloop import IOLoop
from wtform36 import UserForm

class IndexHandle(RequestHandler):
    async def get(self):
        uf = UserForm()
        self.render('personal36.html', uf = uf)


if __name__ == '__main__':
    import os
    # 获取绝对路径
    base_path = os.path.abspath(os.path.dirname(__file__))
    # 设置应用参数
    settings = {
        'template_path':os.path.join(base_path, 'templates'),
        'static_path': os.path.join(base_path, 'static'),
        'static_url_prefix': '/static/',
        'debug': True
    }
    # 创建Tornado应用
    app = Application([('/',IndexHandle)], **settings)
    # 设置监听端口号
    app.listen(8000)
    IOLoop.current().start()

2.2wtforms的Form表单

from wtforms.fields.core import StringField
from wtforms.fields.simple import HiddenField
from wtforms_tornado import Form

class UserForm(Form):
    id = HiddenField("ID")
    username = StringField('用户名')
    nick_name = StringField('昵称')
    email = StringField('邮箱')
    password = StringField('密码')
    phone = StringField('电话')
    language = StringField('语言')

2.3前端

<!DOCTYPE html>
<html lang="cn">
<head>
    <meta charset="UTF-8">
    <!-- Title Page-->
    <title>个人信息</title>
    <!-- Bootstrap CSS-->
    <link href="{{static_url('css/bootstrap.min.css')}}" rel="stylesheet" media="all">
    <!-- Main CSS-->
    <link href="{{static_url('css/theme.css')}}" rel="stylesheet" media="all">
</head>

<body class="animsition">
    <div class="page-wrapper">
        <div class="page-content--bge5">
            <div class="container">
                <div class="login-wrap">
                    <div class="login-content">
                        <div class="login-logo">
                            <a href="#">
                                <img src="{{static_url('img/logo2.png')}}" alt="CoolAdmin">
                            </a>
                        </div>
                        <div class="login-form">
                            <form action="/" method="post">
                                {% autoescape None %}
                                {% for f in uf %}
                                    {% if f.label.text == 'ID' %}
                                        <div class="form-group">
                                            {{f(class_="au-input au-input--full", placeholder=f.label.text)}}
                                        </div>
                                    {% else %}
                                    <div class="form-group">
                                        {{f.label}}
                                        {{f(class_="au-input au-input--full", placeholder=f.label.text)}}
                                    </div>
                                    {% end %}
                                {% end %}
                                <button class="au-btn au-btn--block au-btn--green m-b-20" type="submit">确 认</button>
                            </form>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </div>
</body>
</html>
<!-- end document-->

3.数据的验证

3.1效果展示

在这里插入图片描述

3.2 后端

class IndexHandle(RequestHandler):
    async def get(self):
        uf = UserForm()
        self.render('personal36.html', uf = uf)

    async def post(self):
        uf = UserForm(self.request.arguments)
        # 验证数据
        if uf.validate():
            self.write('成功!!!')
        else:
            self.render('personal36.html', uf = uf)

3.3wtforms的表单

from wtforms.fields.core import StringField
from wtforms.fields.simple import HiddenField
from wtforms_tornado import Form
from wtforms.validators import DataRequired,Length

class UserForm(Form):
    id = HiddenField("ID")
    username = StringField('用户名',validators=(DataRequired(message='请输入用户名'),Length(min=3,max=10,message='请输入3-10位用户名')))
    nick_name = StringField('昵称',validators=(DataRequired(message='请输入昵称'),))
    email = StringField('邮箱',validators=(DataRequired(message='请输入邮箱'),))
    password = StringField('密码',validators=(DataRequired(message='请输入密码'),Length(min=3,max=10,message='请输入3-10位用户名')))
    phone = StringField('电话',validators=(DataRequired(message='请输入电话'),))
    language = StringField('语言',validators=(DataRequired(message='请输入电话'),))

3.4前端

<form action="/" method="post">
                                {% autoescape None %}
                                {% for f in uf %}
                                    {% if f.label.text == 'ID' %}
                                        <div class="form-group">
                                            {{f(class_="au-input au-input--full", placeholder=f.label.text)}}
                                        </div>
                                    {% else %}
                                    <div class="form-group">
                                        {{f.label}}
                                        {{f(class_="au-input au-input--full", placeholder=f.label.text)}}
                                        {% if f.errors %}
                                            {{f.errors}}
                                        {% end %}
                                    </div>
                                    {% end %}
                                {% end %}

4.peewee保存数据

4.1效果展示

在这里插入图片描述

4.2异步创建数据表

from peewee import *
import peewee_async

db = peewee_async.MySQLDatabase('tornado_db', host='127.0.0.1',port=3306,user='root',password='root')
manager = peewee_async.Manager(db)
class User(Model):
    id = AutoField()
    username = CharField(max_length=32)
    nick_name = CharField(max_length=32)
    email = CharField(max_length=32)
    password = CharField(max_length=32)
    phone = CharField(max_length=32)
    language = CharField(max_length=32)

    class Meta:
        database = db
        table_name = 't_user2'

if __name__ == '__main__':
    User.create_table(True)

4.3后端

from tornado.web import Application, RequestHandler
from tornado.ioloop import IOLoop
from wtform36 import UserForm
from models38 import User,manager

class IndexHandle(RequestHandler):
    async def get(self):
        uf = UserForm()
        self.render('personal36.html', uf = uf)

    async def post(self):
        uf = UserForm(self.request.arguments)
        # 验证数据
        if uf.validate():
            del uf.data['id']
            await manager.create(User, **uf.data)
            # 数据的回显
            self.render('personal36.html', uf = uf)
        else:
            self.render('personal36.html', uf = uf)


if __name__ == '__main__':
    import os
    # 获取绝对路径
    base_path = os.path.abspath(os.path.dirname(__file__))
    # 设置应用参数
    settings = {
        'template_path':os.path.join(base_path, 'templates'),
        'static_path': os.path.join(base_path, 'static'),
        'static_url_prefix': '/static/',
        'debug': True
    }
    # 创建Tornado应用
    app = Application([('/',IndexHandle)], **settings)
    # 设置监听端口号
    app.listen(8000)
    IOLoop.current().start()

4.4

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

想成为数据分析师的开发工程师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值