• flask 上传文件


    flask upload

    近日在学习python,接触到了flask框架,刚好客户有个需求,需要在网页上传一个python 代码的zip包,然后使用docker 容器运行这个zip里面的程序,输出结果。
    对于初学文档没什么好说的,http://flask.pocoo.org/docs/0.12/ 从这里学习就好。

    针对我目前的需求,这里贴上代码,比较臃肿,初学所写,见谅。详细请看 gayhub地址:https://github.com/magic-chenyang/flask-upload

    from werkzeug.utils import secure_filename
    from flask import Flask,render_template,jsonify,request,send_from_directory
    import time
    import os
    import base64
    
    app = Flask(__name__)
    UPLOAD_FOLDER='upload'
    app.config['UPLOAD_FOLDER'] = UPLOAD_FOLDER
    basedir = os.path.abspath(os.path.dirname(__file__))
    ALLOWED_EXTENSIONS = set(['txt','png','jpg','xls','JPG','PNG','xlsx','gif','GIF'])
    
    # 用于判断文件后缀
    def allowed_file(filename):
        return '.' in filename and filename.rsplit('.',1)[1] in ALLOWED_EXTENSIONS
    
    # 用于测试上传,稍后用到
    @app.route('/',methods=['GET'],strict_slashes=False)
    def indexpage():
        return render_template('index.html')
    
    
    # 上传文件
    @app.route('/',methods=['POST'],strict_slashes=False)
    def api_upload():
        file_dir = os.path.join(basedir, app.config['UPLOAD_FOLDER'])
        if not os.path.exists(file_dir):
            os.makedirs(file_dir)
        f = request.files['file']  # 从表单的file字段获取文件,file为该表单的name值
    
        if f and allowed_file(f.filename):  # 判断是否是允许上传的文件类型
            fname = secure_filename(f.filename)
            ext = fname.rsplit('.',1)[1]  # 获取文件后缀
            unix_time = int(time.time())
            new_filename = str(unix_time)+'.'+ext  # 修改了上传的文件名
    
            f.save(os.path.join(file_dir, new_filename))  #保存文件到upload目录
            if ext == 'zip':
                z = zipfile.ZipFile(file_dir+'/'+new_filename,'r')
                for zz in z.namelist():
                   z.extract(zz,'/var/lib/docker/volumes/python_test/_data')
            return render_template('result.html',var1=fname)
        else:
            return jsonify({"errno": 1001, "errmsg": u"failed"})
    
    if __name__ == '__main__':
        app.run(debug=True, port=6666,host='0.0.0.0')  #默认127.0.0.1:5000,这里修改了地址和端口方便自己使用
    
  • 相关阅读:
    TensorFlow进阶(六)---模型保存与恢复、自定义命令行参数
    TensorFlow进阶(五)---图与会话
    TensorFlow进阶(四)---名称域和共享变量
    spark中数据倾斜解决方案
    Hive窗口函数之LAG、LEAD、FIRST_VALUE、LAST_VALUE的用法
    java.lang.RuntimeException: HRegionServer Aborted
    hive中的优化问题
    读取hbase数据到mysql
    用mapreduce读取hdfs数据到hbase上
    centos7下安装elasticSearch错误总结(单节点模式)
  • 原文地址:https://www.cnblogs.com/magic-chenyang/p/8117586.html
Copyright © 2020-2023  润新知