flask中关于文件上传的问题以及操作excel的操作

文件上传

需要注意几点,首先最重要的就是需要把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的操作

对于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是列表,里面放的字典对象

你可能感兴趣的:(flask的学习)