会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132358个问题
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask高级 241楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask视图基础和URL 243楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask视图基础和URL 244楼

from  sqlalchemy import create_engine,Column,Integer,String,Float,DECIMAL,Boolean,Date,DateTime,Text,Time
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.dialects.mysql import LONGTEXT
from sqlalchemy.orm import sessionmaker
from datetime import date,datetime,time
import enum
#准备连接数据库基本信息
HOSTNAME='127.0.0.1'
PORT='3306'
DATABASE='first_sqlalchemy'
USERNAME='root'
PASSWORD='root'

DB_URI ="mysql+pymysql://{username}:{password}@{host}:{port}/{db}?charset=utf8".format(username=USERNAME,password=PASSWORD,host=HOSTNAME,port=PORT,db=DATABASE)

#创建数据库引擎
engine=create_engine(DB_URI)

#需求:创建好一个ORM类模型   并映射到指定的数据库中成为 表
#1. 用`declarative_base`根据`engine`创建一个ORM基类。
Base=declarative_base(engine)
#需求:sqlalchemy中常用的字段数据类型有哪些?
#定义一个枚举类
class TagEnum(enum.Enum):
    python="Python"
    flask="FLASK"
    django="DJANGO"


class News(Base):
    __tablename__='news'
    id=Column(Integer,primary_key=True,autoincrement=True)
    price1=Column(Float)
    price2=Column(DECIMAL(10,4))
    title=Column(String(50))
    is_delete=Column(Boolean)
    tag1 = Column(Enum('PYTHON', 'FLASK','DJANGO'))
    tag2=Column(Enum(TagEnum))
    create_time1=Column(Date)
    create_time2=Column(DateTime)
    create_time3=Column(Time)
    content1=Column(Text)
    content2=Column(LONGTEXT)

# Base.metadata.drop_all()
# Base.metadata.create_all()

老师,请问,Enum这里总是报错,是怎么回事呢

image.png

Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask数据库 247楼

python主文件

from flask import Flask,request,render_template,session
from formsCheck import RegisterForm2
import os
import random
app=Flask(__name__)
app.config['SECRET_KEY']= os.urandom(24)
@app.route('/register2/',methods=['GET','POST'])
def login():
    if request.method == 'GET':
        # 自定义验证器 实现验证码验证
        code = random.randint(1000,9999)
        session['code'] = str(code)  # 随机生成一个4位数的随机数
        return render_template("register2.html")
    else:
        form=RegisterForm2(request.form)
        if form.validate():
            return "验证OK"
        else:
            print(form.errors)
            return "验证失败"
if __name__ == '__main__':
    app.run(debug='True')

HTML文件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>注册页面2</title>
</head>
<body>
  <form action="/register2/" method="post">
    <table>
            <tr>
                <th>验证码:</th>
                <td><input type="text" name="coded" size="4" maxlength="4"><span style="background-color: green">{{ session.get('code') }}</span></td>
            </tr>
            <tr>
                <th></th>
                <td><input type="submit" value="注册"></td>
            </tr>
    </table>
</form>
</body>
</html>

工具类py文件

from wtforms import Form,StringField
from wtforms.validators import length,ValidationError
from flask import session

# 定义表单类2
class RegisterForm2(Form):
    code=StringField(validators=[length(min=4,max=4)])
    # 光有长度验证,不能满足验证码验证需求,此时需要自定义验证器来对某字段验证进行强化
    def validate_code(self,field):
        # 取字段field对象上的值来做验证
        print(field.data,session.get('code'))
        if field.data != session.get('code'):
            raise ValidationError(message='输入的验证码不一致!')

出错图,form.data 的数据没有找到

360截图20210509220732114.jpg

Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask高级 249楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask数据库 250楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask视图基础和URL 251楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/虚拟环境 252楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask视图高级 254楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637