会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132360个问题

from sqlalchemy import create_engine, Column, String, Integer, ForeignKey, DateTime
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy.orm import sessionmaker, relationship
from datetime import datetime
import time

USERNAME = 'root'
PASSWORD = '19991108ljf'
HOSTNAME = '127.0.0.1'
PORT = '3306'
DATABASE = 'first_sqlalchemy'

DB_URL = 'mysql+pymysql://{user}:{password}@{host}:{port}/{db}?charset=utf8'\
    .format(user=USERNAME, password=PASSWORD, host=HOSTNAME, port=PORT, db=DATABASE)

engine = create_engine(DB_URL)
Base = declarative_base(engine)
session = sessionmaker(engine)()


# 排序方式1:定义模型时指定模型方式
class Article(Base):
    __tablename__ = 'article'
    id = Column(Integer, primary_key=True, autoincrement=True)
    title = Column(String(50), nullable=False)
    create_time = Column(DateTime, nullable=False, default=datetime.now)
    __mapper_args__ = {
        # 正序
        # 'order_by': create_time
        # 倒叙
        "order_by": create_time.desc()
    }

    def __repr__(self):
        return '<Article(title:%s,create_time:%s)>' % (self.title, self.create_time)


def add_data():
    Base.metadata.drop_all()
    Base.metadata.create_all()
    article_1 = Article(title='title_1')
    session.add(article_1)
    session.commit()
    time.sleep(3)
    article_2 = Article(title='title_2')
    session.add(article_2)
    session.commit()


def oper():
    # 不用再指定排序方式  因为在定义模型的时候  就已指定好排序方式
    articles_2 = session.query(Article).all()
    print(articles_2)


if __name__ == '__main__':
    add_data()
    # oper()

老师,我这串代码报错,提示我得到意外参数‘order_by’怎么解决

屏幕截图 2021-05-16 155911.png

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

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高级 542楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask数据库 543楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask数据库 544楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask数据库 546楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask高级 548楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask数据库 549楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask高级 551楼

表单验证.zip

老师帮忙看一下这个代码,这是个表单验证的,包含文本信息,验证码,还有文件,文件的那个一直报错,说文件为空,老师帮忙看一下

Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask高级 552楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask高级 554楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask高级 555楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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