Python学习笔记-Flask实现简单的投票程序

1.导入flask包

复制代码
from flask import Flask,jsonify,abort,make_response,request,render_template

2.初始化 Flask 应用:

复制代码
app = Flask(__name__)

3. 定义投票种类

复制代码
data = [
    {'id':0,'name':'劳动节','num':0},
    {'id':1,'name':'国庆节','num':0},
    {'id':2,'name':'春节','num':0}
]

4.@app.route('/index'): 定义一个路由,当用户访问 /index 路径时,会执行下面的 index 函数。返回名为 index.html 的模板,并传递一个名为 data 的变量。

复制代码
@app.route('/index')
def index():
    return render_template('index.html',data=data)

5.@app.route('/dianzan'): 定义另一个路由,用于处理点赞功能,用户可以通过此路由向服务器发送请求,为某个特定的 id 点赞。接收一个 id 参数(从请求的查询参数中获取),并尝试增加 data 中对应 id'num' 键的值(模拟点赞操作)。然后,它返回 index.html 模板并传递更新后的 data

复制代码
@app.route('/dianzan')
def dianzan():
    id = request.args.get('id')
    print(f'想要给{id}点赞!!')

    data[int(id)]['num'] +=1
    return render_template('index.html', data=data)

@app.route('/quxiaodianzan'): 定义第三个路由,用于处理取消点赞功能,用户可以通过此路由向服务器发送请求,取消对某个特定 id 的点赞。def quxiaodianzan(): 类似于 dianzan 函数,但它用于减少 data 中对应 id'num' 键的值(模拟取消点赞操作)。

复制代码
@app.route('/quxiaodianzan')
def quxiaodianzan():
    id = request.args.get('id')
    print(f'不想要给{id}点赞!!')
    if data[int(id)]['num'] >0:
        data[int(id)]['num'] -=1
    return render_template('index.html', data=data)

5.启动 Flask 应用,并启用调试模式

复制代码
app.run(debug=True)

6.创建index.html

7.python源码

python 复制代码
#让我们的电脑支持服务访问,需要一个web框架flask
import requests
from flask import Flask,jsonify,abort,make_response,request,render_template

app = Flask(__name__)

data = [
    {'id':0,'name':'劳动节','num':0},
    {'id':1,'name':'国庆节','num':0},
    {'id':2,'name':'春节','num':0}
]
@app.route('/index')
def index():
    return render_template('index.html',data=data)
@app.route('/dianzan')
def dianzan():
    id = request.args.get('id')
    print(f'想要给{id}点赞!!')

    data[int(id)]['num'] +=1
    return render_template('index.html', data=data)
    # return '点赞成功!!!'
@app.route('/quxiaodianzan')
def quxiaodianzan():
    id = request.args.get('id')
    print(f'不想要给{id}点赞!!')
    if data[int(id)]['num'] >0:
        data[int(id)]['num'] -=1
    return render_template('index.html', data=data)

app.run(debug=True)

8.html源码

html 复制代码
<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <h1>这是一个点赞系统</h1>
    <table border="1">
        <tr>
            <td>id</td>
            <td>节日</td>
            <td>点赞数</td>
            <td colspan="2" align="center">操作</td>
<!--            <td>操作</td>-->
        </tr>
        {%for i in data %}
        <tr>
            <td>{{ i.id }}</td>
            <td>{{ i.name }}</td>
            <td>{{ i.num }}</td>
            <td><a href="/dianzan?id={{ i.id }}">点赞</a></td>
            <td><a href="/quxiaodianzan?id={{ i.id }}">取消点赞</a></td>
        </tr>
        {% endfor %}
    </table>
</body>
</html>
相关推荐
wusam15 分钟前
螺蛳壳里做道场:老破机搭建的私人数据中心---Centos下Docker学习04(环境准备)
学习·docker·centos
攸攸太上15 分钟前
Spring Gateway学习
java·后端·学习·spring·微服务·gateway
萧鼎1 小时前
Python调试技巧:高效定位与修复问题
服务器·开发语言·python
Geek之路1 小时前
QT系统学习篇(1)
开发语言·qt·学习
唐·柯里昂7981 小时前
[3D打印]拓竹切片软件Bambu Studio使用
经验分享·笔记·3d
IFTICing1 小时前
【文献阅读】Attention Bottlenecks for Multimodal Fusion
人工智能·pytorch·python·神经网络·学习·模态融合
大神薯条老师1 小时前
Python从入门到高手4.3节-掌握跳转控制语句
后端·爬虫·python·深度学习·机器学习·数据分析
程序员爱德华1 小时前
Python环境安装教程
python
sml_54211 小时前
【笔记】连续、可导、可微的概念解析
笔记·线性代数
huanxiangcoco1 小时前
152. 乘积最大子数组
python·leetcode