需要注意几点,首先最重要的就是需要把form表单的enctype=“multipart/form-data”
必须使用post方法。
如果不使用form表单,可以借助ajax的方法,用js中的FormData对象。
var file = $("#fileID")[0].files[0];//获取指定ID的文件信息
var formData = new FormData();//创建FormData对象,将所需的信息封装到内部,以键值对的方式
formData.append("file",file);//参数封装格式,可以是文件,亦可以是普通的字符串
$.ajax({
type:"post",
url:url,
async:false,
cache:false,//不需要缓存操作
data:formData,//传递的参数就是FormData
contentType:false,//由于提交的对象是FormData,所以要在这里更改上传参数的类型
processData:false,//提交对象是FormData,不需要对数据做任何处理
success:function(data){
........
},
complete:function(){
........
}
});
对于excel的操作需要用到两个库xlrd(读取内容)和xlw的(写入内容)
book = xlrd.open_workbook(file_contents=f.read()) # 里面可写文件内容,也可以是文件的地址。
# book = xlrd.open_workbook(file_name = '')
table = book.sheet_by_index(0) # 找到工作的表,也可以用sheet_by_name()
table.ncols # 是总列数
table.nrows # 是总行数
table.cell(0,0).value # 是具体格子的数值
######## 写内容
import xlwt
#只能写不能读
stus = [['姓名', '年龄', '性别', '分数'],
['mary', 20, '女', 89.9],
['mary', 20, '女', 89.9],
['mary', 20, '女', 89.9],
['mary', 20, '女', 89.9]
]
book = xlwt.Workbook()#新建一个excel
sheet = book.add_sheet('case1_sheet')#添加一个sheet页
row = 0#控制行
for stu in stus:
col = 0#控制列
for s in stu:#再循环里面list的值,每一列
sheet.write(row,col,s)
col+=1
row+=1
book.save('stu_1.xls')#保存到当前目录下
还有一种简单的方法就是使用flask中的flask-excel 包
import flask_excel as excel
excel.make_response_from_records(items, "xlsx", file_name="all_content") #items是列表,里面放的字典对象