Django上传xlsx文件直接转化为DataFrame或直接保存的方法
短信预约 -IT技能 免费直播动态提醒
使用Django框架搭建后端服务器,后台接收前端传递过来xlsx的文件,直接将前端传递的文件转化为DataFrame或直接将文件保存。
urls.py
from django.urls import path
from . import views
# 为 URL 名称添加命名空间
app_name = 'report'
urlpatterns = [
# 上传报告
path('/upload_report/', views.upload_report, name='upload_report'),
]
view.py
def handle_uploaded_file(file, path):
"""
保存上传的文件
:param file: 上传的文件
:param path: 存储路径(包含文件名)
:return:
"""
with open(path, 'wb+') as destination:
# 将文件分块
for chunk in file.chunks():
# 写文件
destination.write(chunk)
def upload_report(request):
"""
上传报表
:param request:
:return:
"""
# 获取文件
file = request.FILES.get('file')
# 报告存储路径
path = 'reports/' + file.name
# 1.直接转化为DataFrame
file_df = pandas.read_excel(file)
# 数据处理
# DataFrame保存为xlsx
file_df.to_excel(path, index=False, header=None, float_format='%.2f')
# 2。直接保存上传的文件
handle_uploaded_file(request.FILES['file'], path)
return JsonResponse({'reports': 1})
到此这篇关于Django上传xlsx文件直接转化为DataFrame或直接保存的方法的文章就介绍到这了,更多相关Django上传xlsx保存内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341