IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> python flask修改及删除表格信息 -> 正文阅读

[Python知识库]python flask修改及删除表格信息

基于python&flask 修改及删除表格信息

图片

假设有两个用户的信息,在表中展示(分别为姓名,年龄,手机号),如下图:
在这里插入图片描述
支持修改及删除,点击修改时(假设只允许修改年龄及手机号),弹出如下图:
在这里插入图片描述
修改完,点击“用户更新”后,返回到127.0.0.1:5000/user页面

在这里插入图片描述
点击第二行的“删除”后,删除相关信息
在这里插入图片描述

python代码部分

from flask import Flask, render_template, request, redirect

app = Flask(__name__)

#这里可以作为首页,但为了展示/usr下的用户信息,做了重定向
@app.route("/")
def index2():
    return redirect('/user')

#假设已经存在一些用户(这里没有做用户信息的添加或者注册)
users=[{'name': 'xiaozhang', 'age': 18, 'phone':'123456'},{'name':'xiaoli','age':20,'phone':'567890'}]

#展示user信息
@app.route('/user')
def show_user():
    return render_template('/user.html', users=users)

#删除某个用户
@app.route('/del')
def del_user():
    name=request.args.get('name')
    for user in users:
        print(user)
        print(name)
        if user['name'] == name:
            users.remove(user)
            return redirect('/user')
    else:
    	#这里可以做个删除失败或者未找到用于的提示页面
        return "no foud"
        
#update要支持post和get两种方法,点击“修改”支持get,点击“用户更新”支持post
@app.route('/update',methods=['POST','GET'])
def update_info():
    if request.method == 'POST':
        name = request.form.get('name')
        age = request.form.get('age')
        phone = request.form.get('phone')

        for user in users:
            if user['name'] == name:
                user['age'] = age
                user['phone'] = phone
                return redirect('/user')
        return 'no found'
    else:
        name=request.args.get('name')
        for user in users:
            if user['name'] == name:
                return render_template('update.html', user=user)

if __name__ == '__main__':
    app.run(debug=True)

user.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>用户信息</title>
</head>
<body>
<h1>用户信息</h1>
<span>当前用户人数是:{{ users | length }}</span>
<table border="1"  cellspacing="0" width="50%">
    {% for user in users %}
    <tr>
        <td>{{ loop.index }}</td>
        <td>{{ user.name }}</td>
        <td>{{ user.age }}</td>
        <td>{{ user.phone }}</td>
        <td><a href="javascript:;" onclick="update('{{ user.name }}')">修改</a>
            <a href="javascript:;" onclick="del('{{ user.name }}')">删除</a> </td>
    </tr>
{% endfor %}
<script>
    function del(name){
        location.href='/del?name='+name
    }
    function update(name){

        location.href='/update?name='+name
    }

</script>
</table>
</body>
</html>

update.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>更新用户</title>
</head>
<body>
<form action="/update" method="POST">
<p><input type="text" name="name" placeholder="用户名" value="{{ user.name }}" disabled</p>
<p><input type="text" name="age" placeholder="年龄" value="{{ user.age }}" </p>
<p><input type="text" name="phone" placeholder="手机号" value="{{ user.phone }}" </p>
<p><input type="submit" value="用户更新"</p>
</form>
</body>
</html>
  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2021-08-31 15:24:46  更:2021-08-31 15:25:31 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/15 12:06:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码