Flask的使用

本文介绍了Python轻量级Web框架Flask的基础知识和使用方法。通过创建工程、配置目录,展示了如何使用Flask实现简单的HTTP路由,包括静态文件处理和表单数据处理。文章还详细解释了Flask的路由规则,包括变量规则和转换器,以及如何利用url_for()函数动态构建URL。此外,还涵盖了处理静态文件和表单数据的基本操作。
摘要由CSDN通过智能技术生成

🌞欢迎来到python的世界 
🌈博客主页:卿云阁

💌欢迎关注🎉点赞👍收藏⭐️留言📝

🌟本文由卿云阁原创!

🌠本阶段属于练气阶段,希望各位仙友顺利完成突破

📆首发时间:🌹2021年4月18日🌹

✉️希望可以和大家一起完成进阶之路!

🙏作者水平很有限,如果发现错误,请留言轰炸哦!万分感谢!


🍈 一、Flask的介绍

Flask是一个使用 Python 编写的轻量级 Web 应用框架。


 🍉二. Flask的简单使用

1、创建工程

选择new project创建工程,输入项目名,选择配置好的

虚拟环境

2、配置工程目录

在app.py中的代码如下

from flask import Flask, render_template

app = Flask(__name__)
app.config['SECRET_KEY'] = '1456719640@qq.com'


@app.route("/")
def root():
    """
    主页
    :return: Index.html
    """
    return render_template('Index.html')


if __name__ == '__main__':
    app.run(debug=True, host='127.0.0.1', port='5000')

static文件夹用来存放css、JavaScript、image等静态资源文件

templates文件夹,该文件夹用来存放HTML文件

在templates文件夹下新建index.html文件,index.html文件的代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<h1>hello world</h1>
</body>
</html>

至此,在app.py中运行main函数,进去127.0.0.1::5000即可看到index.html中的内容!


🍊三,Flask 应用程序

from flask import Flask
 app = Flask(__name__)
 @app.route('/')
 def hello_world():
     return 'Hello World'
 if __name__ == '__main__':
     app.run()

在项目中导入Flask模块是强制性的。

Flask构造函数将当前模块的名称(__name__)作为参数。

Flask类的route()函数是一个装饰器,它告诉应用程序哪个URL应该调用相关的函数。

app.route(rule, options)

rule 参数表示与该函数绑定的URL。options 是要转发给底层Rule对象的参数列表。

在上面的实例中,'/' URL与hello_world()方法绑定。 因此,在浏览器中打开Web服务器的主页时,将呈现此函数的输出。

最后,Flask类的run()方法在本地开发服务器上运行应用程序。

app.run(host, port, debug, options)


🍋四、Flask 路由(Route)

现代Web框架使用路由技术来帮助用户记住应用程序URL。 无需从主页导航即可直接访问所需页面。

Flask中的route()装饰器用于将URL绑定到函数。 例如 -

@app.route('/hello')
 def hello_world():
     return 'hello world'

这里,URL /hello规则绑定到hello_world()函数。 因此,如果用户访问URL : http://localhost:5000/hello ,就会调用hello_world()函数,这个函数中的执行的结果输出将在浏览器中呈现。

应用程序对象的add_url_rule()函数也可用于将URL与函数绑定,如上例所示,使用route()。


Flask 变量规则

可以通过将可变部分添加到规则参数来动态构建URL。 这个变量部分被标记为<variable-name>。 它作为关键字参数传递给规则所关联的函数。

在以下示例中,route()装饰器的规则参数包含附加到URL /hello的<name>变量部分。 因此,如果在浏览器中输入URL: http://localhost:5000/hello/nhooo,那么 ‘nhooo’ 将作为参数提供给hello()函数。

参考如下代码 -

from flask import Flask
 app = Flask(__name__)
 @app.route('/hello/<name>')
 def hello_name(name):
     return 'Hello %s!' % name
 if __name__ == '__main__':
     app.run(debug = True)

接下来,打开浏览器并输入URL => http://localhost:5000/hello/nhooo。在浏览器中将看到Hello nhooo

除了默认的字符串变量部分之外,还可以使用以下转换器构造规则 -

 在下面的代码中,使用了所有这些构造函数。

from flask import Flask
 app = Flask(__name__)
 @app.route('/blog/<int:postID>')
 def show_blog(postID):
     return 'Blog Number %d' % postID
 @app.route('/rev/<float:revNo>')
 def revision(revNo):
     return 'Revision Number %f' % revNo
 if __name__ == '__main__':
     app.run()

从Python Shell运行上述代码。 在浏览器中访问URL => http:// localhost:5000/blog/11。

给定的数字值作为:show_blog()函数的参数。 浏览器显示以下输出 -

Blog Number 11

在浏览器中输入此URL - http://localhost:5000/rev/1.1

revision()函数将浮点数作为参数。 以下结果出现在浏览器窗口中 -

Revision Number 1.100000

Flask的URL规则基于Werkzeug的路由模块。 这确保了形成的URL是唯一的,并且基于Apache制定的先例。

考虑以下脚本中定义的规则 -

from flask import Flask
 app = Flask(__name__)
 @app.route('/flask')
 def hello_flask():
     return 'Hello Flask'
 @app.route('/python/')
 def hello_python():
     return 'Hello Python'
 if __name__ == '__main__':
     app.run()

两条规则看起来都很相似,但在第二条规则中,使用了尾部斜线(/)。 因此,它变成了一个规范的URL。 因此,使用/python或/python/返回相同的输出。 但是,在第一条规则的情况下, URL:/flask/会导致404 Not Found页面。


Flask URL构建

url_for()函数对于动态构建特定函数的URL非常有用。 该函数接受函数的名称作为第一个参数,并接受一个或多个关键字参数,每个参数对应于URL的变量部分。

from flask import Flask, redirect, url_for
app = Flask(__name__)
@app.route('/admin')
def hello_admin():
    return 'Hello Admin'
@app.route('/guest/<guest>')
def hello_guest(guest):
    return 'Hello %s as Guest' % guest
@app.route('/user/<name>')
def user(name):
    if name =='admin':
        return redirect(url_for('hello_admin'))
    else:
        return redirect(url_for('hello_guest',guest = name))
if __name__ == '__main__':
    app.run(debug = True)

User()函数检查收到的参数是否与’admin’匹配。 如果匹配,则使用url_for()将应用程序重定向到hello_admin()函数,否则将该接收的参数作为guest参数传递给hello_guest()函数

localhost:5000/admin

Hello Admin

localhost:5000/guest/qingyun

Hello qingyun as Guest

Flask 静态文件

Web应用程序通常需要一个静态文件,例如支持显示网页的JavaScript文件或CSS文件。 通常,可以通过配置Web服务器提供这些服务,但在开发过程中,这些文件将从包中的静态文件夹或模块旁边提供,它将在应用程序的/static上提供。

使用特殊的端点“静态”来为静态文件生成URL。

在以下示例中,index.html中的HTML按钮的OnClick事件调用hello.js中定义的javascript函数,该函数在Flask应用程序的URL => / 中呈现。

index.html

<html>
    <head>
       <script type = "text/javascript"
          src = "{{ url_for('static', filename = 'hello.js') }}" ></script>
    </head>
    <body>
       <input type = "button" onclick = "sayHello()" value = "Say Hello" />
    </body>
 </html>

app.py

from flask import Flask, render_template
app = Flask(__name__)
@app.route("/")
def index():
    return render_template("index.html")
if __name__ == '__main__':
     app.run(debug = True)

hello.js

function sayHello() {
    alert("Hello World")
 }

 


Flask 表单处理

我们已经看到,可以在URL规则中指定http方法。URL映射的函数接收到的表单数据可以以字典对象的形式收集,并将其转发给模板以在相应的网页上呈现它。

在以下示例中,URL => / 呈现具有表单的网页( student.html)。填充的数据会提交到触发result()函数的URL => /result 中。

results()函数收集字典对象中request.form中存在的表单数据,并将其发送给 result.html 并显示出来。该模板动态呈现表单数据的HTML表格。

app.py

from flask import Flask, render_template, request
app = Flask(__name__)
@app.route('/')
def student():
    return render_template('student.html')
@app.route('/result',methods = ['POST', 'GET'])
def result():
    if request.method == 'POST':
        result = request.form
        return render_template("result.html",result = result)
if __name__ == '__main__':
     app.run(debug = True)

student.html

<html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>Flask示例</title>
 </head>
    <body>
       <form action = "http://localhost:5000/result" method = "POST">
          <p>姓名 <input type = "text" name = "Name" /></p>
          <p>物理分数: <input type = "text" name = "Physics" /></p>
          <p>化学分数: <input type = "text" name = "Chemistry" /></p>
          <p>数学分数: <input type ="text" name = "Mathematics" /></p>
          <p><input type = "submit" value = "提交" /></p>
       </form>
    </body>
 </html>

result.html

<html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>Flask示例</title>
 </head>
    <body>
       <table border = 1>
          {% for key, value in result.items() %}
             <tr>
                <th> {{ key }} </th>
                <td> {{ value }} </td>
             </tr>
          {% endfor %}
       </table>
    </body>
 </html>

 

 


  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
jflash是一种常用于嵌入式系统开发的烧录软件,用于将固件程序烧录到目标设备的闪存中。下面是一个简单的jflash使用教程: 1. 准备工作:首先,确保你已经安装了J-Link驱动程序,并将J-Link与目标设备正确连接。 2. 打开jflash:双击打开jflash应用程序。 3. 创建新工程:选择"New"按钮或者点击菜单栏中的"File",然后选择"New"来创建一个新的jflash工程。 4. 选择目标设备:在弹出的对话框中,选择你要烧录固件的目标设备类型。如果你的设备不在列表中,可以选择"Other Devices"并手动输入设备信息。 5. 配置连接:在"Target"选项卡中,选择"Settings"按钮来配置连接参数,例如调试接口和目标设备的电压等级。确保配置正确,然后点击"OK"保存设置。 6. 添加待烧录的文件:在"File"选项卡中,点击"Add"按钮来添加待烧录的文件。可以选择单个文件或者选择整个文件夹。确保选择了正确的固件文件和路径。 7. 配置烧录参数:在"Options"选项卡中,可以配置烧录相关的参数,例如擦除闪存、烧录速度等。根据需要进行个性化设置。 8. 开始烧录:在"Project"选项卡中,点击"Download"按钮来开始烧录固件。烧录过程将显示在"Output"窗口中,可以查看烧录的进度和状态。 9. 烧录完成:烧录完成后,"Output"窗口将显示成功的信息。此时,你可以重启目标设备,运行烧录好的固件。 10. 保存工程:为了方便将来的使用,你可以选择"Save Project"来保存当前的jflash工程。 以上就是一个简单的jflash使用教程,希望对你有所帮助。请注意,在操作过程中遵循相关的安全操作规程,确保不会对目标设备造成损坏。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

卿云阁

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

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

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

打赏作者

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

抵扣说明:

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

余额充值