python-flask-上传多个文件并存储

本地环境:win10 / centos6 , python3


flask入门看这里:

python-flask结合bootstrap实现网页小工具实例-半小时速通版_bootstrap flask-CSDN博客

https://blog.csdn.net/pxy7896/article/details/137854455

动态添加和删除表格中的行,看这里:

javascript-动态增加和删除表格的行-CSDN博客

https://blog.csdn.net/pxy7896/article/details/141030235


问题描述

在前台上传1~N个文件,后台接收并存储。

实现效果

点击"添加峰图"按钮,可以不断加行:

实际的html内容类似:

后台则需要接收这些附件(前一个input也要)。

解决方案

在前台构建一个form,在里面放一个table,然后在列中增加文件上传按钮,如下所示:

html 复制代码
<form action="run_command_ab1" id="main_form" >
	<div id="suborderlist" class="row col-md-12">
		<table>
			<!-- 略去一些内容 -->
			<!-- 这是编号 -->
			<td name="rowIdx" style="width:10%;"></td>
			<td style="width:40%;">
				<input name="attach" type="file" id="customFile">
            </td>
		</table>
</form>

提交按钮的id是submitButton,加上点击操作:

javascript 复制代码
$("#submitButton").click(function () {
	// 构造数据
	var formData = new FormData();
	var attachList = document.getElementsByName("rowIdx");
    for (var x=0; x<attachList.length; x++) {
    	// 接收前面input的细节,略
		// 拼接一下文件的id
		var idx = "attach." + attachList[x].innerText.toString();
    	var attachFile = document.getElementById(idx).files[0];
    	if (attachFile == null) {
			// 处理空文件
    		var blob = new Blob([], {type: "text/plain;charset=utf-8"});
    		formData.append("subAttach", blob);
    	} else {
    		formData.append("subAttach", attachFile);
    	}
    }
    // 剩余数据
    // 这里main_form是当前整个form的id
	formData.append("ab1Order", $("#main_form").serialize());
    $.ajax({
        type: 'POST',
        url: "/run_command_ab1",
        data: formData,
		processData: false, // jQuery不要处理发送的数据
        contentType: false, // jQuery不要设置Content-Type请求头
        success: function (resp) {
			// 做一些处理
		}
    });
});

在后台这样写:

python 复制代码
@app.route('/run_command_ab1', methods=['POST'])
def run_command_ab1():
    if request.method == 'POST':
        #print(request.form) 
        # ImmutableMultiDict([('ab1Order', 'sampleId=test&target=313&target=21&target=')])
        # 所以这样提取信息
        info = request.form['ab1Order']
        
        #print(request.files)
        # ImmutableMultiDict([('subAttach', <FileStorage: 'xxx.ab1' ('application/octet-stream')>)])
        # 这样获取文件列表
        files = request.files.getlist('subAttach')
        # 遍历
        for f in files:
            f.save("/this/is/the/path/" + f.filename)
        return '文件已上传成功!'

END.

相关推荐
光而不耀@lgy33 分钟前
C++初登门槛
linux·开发语言·网络·c++·后端
lkbhua莱克瓦2437 分钟前
用C语言实现——一个中缀表达式的计算器。支持用户输入和动画演示过程。
c语言·开发语言·数据结构·链表·学习方法·交友·计算器
Mr__Miss41 分钟前
面试踩过的坑
java·开发语言
偶尔微微一笑42 分钟前
AI网络渗透kali应用(gptshell)
linux·人工智能·python·自然语言处理·编辑器
啊丢_43 分钟前
C++——Lambda表达式
开发语言·c++
Chh07151 小时前
《R语言SCI期刊论文绘图专题计划》大纲
开发语言·r语言
Yeats_Liao1 小时前
Go 语言 TCP 端口扫描器实现与 Goroutine 池原理
开发语言·tcp/ip·golang
Thomas_YXQ2 小时前
Unity3D IK解算器技术分析
开发语言·搜索引擎·unity·全文检索·unity3d·lucene
船长@Quant2 小时前
文档构建:Sphinx全面使用指南 — 基础篇
python·markdown·sphinx·文档构建
喵手2 小时前
从 Java 到 Kotlin:在现有项目中迁移的最佳实践!
java·python·kotlin