当前位置:   article > 正文

flask excel_flask_excel

flask_excel

文件的下载
from flask import send_from_directory

@excel_bp.route(’/get_attachment/path:filename’)
def get_attachment(filename):
return send_from_directory(app.config[‘UPLOAD_FOLDER’],filename,as_attachment=True)

文件的上传
(1)html中

(2)后端获取,保存

file = request.files.get(‘文件名’) # 获取文件

filename = file.filename # 获取文件名

file.save(os.path.join(FILE_DIR,filename)) # 保存文件
(3)当然 要对文件名,文件类型进行判断;存储路径也要进行判断

可以使用werkzeug中的 secure_filename

判断文件类型

ALLOWED_EXTENSIONS = [‘xls’, ‘xlsx’]

def allowe_file(filename):
‘’’
限制上传的文件格式
:param filename:
:return:
‘’’
return ‘.’ in filename and filename.rsplit(’.’,1)[1] in ALLOWED_EXTENSIONS
修改文件名

import os
import datetime,uuid

def change_filename(filename):
‘’’
修改文件名称
:param filename:
:return:
‘’’
fileinfo = os.path.splitext(filename)
filename = datetime.datetime.now().strftime("%Y%m%d%H%M%S")+str(uuid.uuid4().hex)+fileinfo[-1]
return filename
判断储存路径

if not os.path.exists(FILE_DIR):
os.makedirs(FILE_DIR)

python的excel操作

通过xlrd读文件

安装:pip install xlrd

通过 xlrd 打开excel,组装数据

import xlrd

def get_data(filename,method=‘r’):
‘’’
改变数据结构 – 方便前端显示
:param filename: 文件名
:param method: 按照 列或者 行 返回数据
‘’’
data = xlrd.open_workbook(filename)
table= data.sheets()[0]
nrows = table.nrows # 行数
ncols = table.ncols # 列数
if method == ‘r’:
row_list = [ table.row_values(i) for i in range(0,nrows)] # 所有行的数据
return row_list
elif method == ‘c’:
col_list = [ table.col_values(i) for i in range(0,ncols)] # 所有列的数据
return col_list
前端显示

< thead >
< tr >
{% for title in datalist[0] %}
< th >{ title }< / th >
{ % endfor % }
< /tr >
< / thead >
< tbody >
{ % for row in datalist[1:] % }
< tr >
{ % for item in row % }
{ { item } }
{ % endfor % }
< /tr >
{ % enfor % }
< / tbody >
< / table >
通过xlwt写文件

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/464570
推荐阅读
相关标签
  

闽ICP备14008679号