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)

[email protected]('/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>
相关推荐
小幽余生不加糖16 分钟前
反无人机系统:技术利刃如何守护低空安全?
笔记·学习·安全·无人机
广州山泉婚姻17 分钟前
Python 爬虫简单示例
爬虫·python
站大爷IP32 分钟前
Python文件读写操作详解:从基础到实战
python
魔芋红茶1 小时前
Spring 源码学习 3:工厂后处理器
java·学习·spring
Ting-yu1 小时前
零基础学习Redis(14) -- Spring中使用Redis
redis·学习·spring
m0_625686551 小时前
Day39
python
站大爷IP1 小时前
用 Python 制作简单小游戏教程:手把手教你开发猜数字游戏
python
小高求学之路1 小时前
MinIO centos 7 离线(内网) 一键部署安装
python·centos·numpy
天才测试猿1 小时前
2025最新软件测试面试题总结【附文档】
自动化测试·软件测试·python·测试工具·面试·职场和发展·测试用例
.Eyes1 小时前
OBCP第二章 OceanBase 存储引擎高级技术学习笔记
笔记·学习·oceanbase