我的编程空间,编程开发者的网络收藏夹
学习永远不晚

flask上传作品之dbm操作怎么实现

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

flask上传作品之dbm操作怎么实现

本篇内容主要讲解“flask上传作品之dbm操作怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“flask上传作品之dbm操作怎么实现”吧!

    一,前言

    需求:

    活动需要手动定为历史活动,不要按照年份自动变为历史活动。

    二,dbm数据库操作-match_set

    2.1,后端响应请求

    增加了应该路由-match_set。

    flask上传作品之dbm操作怎么实现

    上文代码块解释:
    这部分是,前端用户请求match_set,后端返回给前端的内容。
    原理就是遍历我们需要的dbm数据库里面的内容,放到合适的位置。传递给前端。
    如下:

    022|包头市第二界文化旅游创意作品大赛|2,2023|朱博的个人作品大赛|,2024|朱博的大赛|,2025|朱博我的的大赛|,2026|朱博我的的大赛|,2027|朱博我的你的的
    大赛|,2028|朱博我的你的的大赛|,2029|朱博我的你的的大赛|,2030|朱博我的你的的大赛|', ‘pw_nums’: ‘3’, ‘btn_3’: ‘大赛成绩|/result’, ‘btn_1’: ‘上传
    作品|/new_post’, ‘match_name’: ‘朱博我的你的的大赛’, ‘upload’: ‘false’, ‘btn_4’: ‘往期回顾|/past’, ‘time’: ‘1’, ‘match’: ‘2030’, ‘time_3_posts’
    : ‘’, ‘btn_5’: ‘评委入口|/admin’, ‘time_2_posts’: ‘1’, ‘switch’: ‘’, ‘picture’: ‘’, ‘image’: ‘u=2566611882,1193878858&fm=253&fmt=auto&app=138&f
    =JPEG.webp’

    测试用的,有点乱哈哈。

    2.2,前端返回表单

     <label for="">目标赛事名称:</label> <input type="text" name="match_name" {% if time %}value="{{match_name}}"{% endif %}>  <label for="">目标赛事标识:</label>  <input type="text" name="match" {% if time %}value="{{match}}"{% endif %}>  <label for="">目标赛事设置(1:不设置为历史历史赛事 2:设置为历史历史赛事):</label>  <input type="text" name="switch">  <button class="button button--secondary" type="submit">提交</button>

    前端如上,非常简单的一个收集表单。
    前端发起提交按钮,提交给后端,后端再处理。

    2.3,后端再次响应,保存操作

    if request.method == "POST":

    上文代码解释:判断,前端是以post的方式传到后端的。

     if key == "match":     #print("当前路径为1")        if "past_matchs" in db_config:            if value not in db_config["past_matchs"].decode():                flag=0            else:                #print("当前路径为4")                past_matchss = db_config["past_matchs"].decode().split(',')                #print(db_config["past_matchs"].decode())                #print(past_matchss)                for i in past_matchss:                    jj=i                    break

    上文代码块解释:【这一块代码很多。展示部分代码,下文贴全部代码。】
    这里的逻辑即为复杂,因为遍历的时候,我们之间遍历他的key和value。
    我们找到目标key == “match”:。
    下文判断。如果我们的dbm数据库里含有past_matchs的话执行{
    如果我们的目标value值不再dbm数据库里,我们吧flag赋值为0.下面判断,如果flag==0说明,{该赛事不存在}
    如果value值在dbm数据库里{

    past_matchss = db_config["past_matchs"].decode().split(',')

    获取到目标值。

    flask上传作品之dbm操作怎么实现

    如上文代码逻辑。【大体来讲:我重新写了一个类别,因为不能删除的原因,我选择重新赋值遍历,累加】

    最后:

    if(flag==0):flash("该赛事不存在")if(flag==1):    db.session.commit()    flash("提交成功", "success")return redirect(url_for('match_set'))

    上文代码解释:
    因为我们之前给flag赋值为1。如果没有目标value在我们的数据库里的话,falg会赋值为0。
    不执行更改数据库的操作。反之更改。
    最后重定向到目标页面,此部分结束!

    三,附代码

    @min_role_required(ROLES["mod"])@app.route('/match_set/', methods=['GET', 'POST'])def match_set():    flag=1    if request.method == "POST":        switch2=''        for key, value in request.form.items():            if key == "switch":                switch2=value        for key, value in request.form.items():            # print("标记key",key)            # print("标记value",value)            if key == "match":                #print("当前路径为1")                if "past_matchs" in db_config:                    if value not in db_config["past_matchs"].decode():                        flag=0                    else:                        #print("当前路径为4")                        past_matchss = db_config["past_matchs"].decode().split(',')                        #print(db_config["past_matchs"].decode())                        #print(past_matchss)                        for i in past_matchss:                            jj=i                            break                        iip=0                        for i in past_matchss:                            if(iip>0):                                #print(i)                                if(value not in i):                                    jj=jj+","+i                                if(value in i):                                    #print(switch2)                                    if(i.split("|")[2]==switch2):                                        jj=jj+","+i                                        #print("正确")                                    else:                                        #print(value+"|"+request.form.get('match_name')+"|"+switch2)                                        jj=jj+","+(value+"|"+request.form.get('match_name')+"|"+switch2)                                        #print("错误")                                    #print(i)                            iip=iip+1                        db_config["past_matchs"]=jj                else:                    db_config["past_matchs"] = f"{value}|{request.form.get('match_name')}|{request.form.get('switch')}"                    #print("当前路径为3")        if(flag==0):            flash("该赛事不存在")        if(flag==1):            db.session.commit()            flash("提交成功", "success")        return redirect(url_for('match_set'))    attrs_dict = {}    for k in db_config.keys():        attrs_dict[k.decode()] = db_config[k].decode()    #print(attrs_dict)    past_matchs = db_config["past_matchs"].decode().split(',')    past_qian=db_config["match"].decode()    pasts = []    for match_tuple in past_matchs:        if not match_tuple:            continue        match_mark = match_tuple.split("|")[0]        match_name = match_tuple.split("|")[1]        match_zhuangtai = match_tuple.split("|")[2]        data = {}        data["title"] = match_name        data["count"] = Post.query.filter_by(match=match_mark).count()        data["url"] = url_for('index', match=match_mark)        data["zhuangtai"] = match_zhuangtai        data["muqian"] = past_qian        data["biaoshi"]=match_mark        pasts.append(data)    #return render_template('past.html', pasts=pasts)    return render_template('admin/match_set.html', pasts=pasts)

    到此,相信大家对“flask上传作品之dbm操作怎么实现”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    免责声明:

    ① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

    ② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

    flask上传作品之dbm操作怎么实现

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档

    猜你喜欢

    flask上传作品之dbm操作怎么实现

    本篇内容主要讲解“flask上传作品之dbm操作怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“flask上传作品之dbm操作怎么实现”吧!一,前言需求:活动需要手动定为历史活动,不要按照
    2023-06-30

    servlet3如何实现文件上传操作

    这篇文章主要为大家展示了“servlet3如何实现文件上传操作”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“servlet3如何实现文件上传操作”这篇文章吧。在Servlet2.5中,我们要实现
    2023-05-30

    Flask接收上传图片怎么实现

    本篇内容介绍了“Flask接收上传图片怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!思路整理:接收图片->定义一个图片存放的位置->
    2023-07-02

    Java操作FTP实现上传下载功能

    这篇文章主要为大家详细介绍了Java如何通过操作FTP实现上传下载的功能,文中的示例代码讲解详细,对我们学习Java有一定帮助,需要的可以参考一下
    2022-11-13

    Linux操作系统怎么实现的传真系统

    本篇内容主要讲解“Linux操作系统怎么实现的传真系统”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux操作系统怎么实现的传真系统”吧!传真是企业中的常规使用,许多商贸往来的信息交换都须要
    2023-06-17

    PHP Linux脚本操作实践:实现FTP上传与下载

    在现代的Web开发中,与服务器之间的文件传输是一个常见的需求。而FTP(File Transfer Protocol)是一种被广泛应用于文件传输的协议。本文将介绍如何使用PHP在Linux环境下实现FTP的上传与下载,并给出具体的代码示例。
    2023-10-21

    golang怎么实现mysql操作

    这篇文章主要介绍“golang怎么实现mysql操作”,在日常操作中,相信很多人在golang怎么实现mysql操作问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”golang怎么实现mysql操作”的疑惑有所
    2023-07-06

    C#操作Word怎么实现

    这篇文章主要介绍“C#操作Word怎么实现”,在日常操作中,相信很多人在C#操作Word怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#操作Word怎么实现”的疑惑有所帮助!接下来,请跟着小编一起来
    2023-06-18

    PHP中怎么实现目录操作和文件操作

    今天就跟大家聊聊有关PHP中怎么实现目录操作和文件操作,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、目录操作首先介绍的是一个从目录读取的函数,opendir(),readdir(
    2023-06-17

    SVN检出操作怎么实现

    本篇内容介绍了“SVN检出操作怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!Apache Subversion 通常被缩写成 SVN
    2023-06-04

    编程热搜

    • Python 学习之路 - Python
      一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
      Python 学习之路 - Python
    • chatgpt的中文全称是什么
      chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
      chatgpt的中文全称是什么
    • C/C++中extern函数使用详解
    • C/C++可变参数的使用
      可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
      C/C++可变参数的使用
    • css样式文件该放在哪里
    • php中数组下标必须是连续的吗
    • Python 3 教程
      Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
      Python 3 教程
    • Python pip包管理
      一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
      Python pip包管理
    • ubuntu如何重新编译内核
    • 改善Java代码之慎用java动态编译

    目录