python存储文件代码_Django接收照片储存文件的实例代码

后端:

from rest_framework.views import APIView

from car import settings

from django.shortcuts import render, redirect, HttpResponse

from dal import models

from django.http import JsonResponse

import os

BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

class Image(APIView):

def post(self, request):

file_obj = request.FILES.get('send',None)

print("file_obj",file_obj.name)

file_path = os.path.join(BASE_DIR, 'media', 'user/img', file_obj.name)

print("file_path", file_path)

with open(file_path, 'w') as f:

for chunk in file_obj.chunks():

f.write(chunk)

message = {}

message['code'] = 200

return JsonResponse(message)

前端ajax:

下面在看下在Django中接收文件并存储

首先是一个views函数的例子

def get_user_profiles(request):

if request.method == 'POST':

myFile = request.FILES.get("filename", None)

if myFile:

dir = os.path.join(os.path.join(BASE_DIR, 'static'),'profiles')

destination = open(os.path.join(dir, myFile.name),

'wb+')

for chunk in myFile.chunks():

destination.write(chunk)

destination.close()

return HttpResponse('ok')

这是一个简单的接收客户端上传的头像文件并保存的例子,应该看过这个就已经大体会使用接收文件了

但是这里的filename是客户端上传的文件名,也可能是像下面这样的表单

如果不知道固定上传的文件名,想要客户端上传什么文件就以其上传的名字命名可以这么写

def get_user_profiles(request):

if request.method == 'POST':

if request.FILES:

myFile =None

for i in request.FILES:

myFile = request.FILES[i]

if myFile:

dir = os.path.join(os.path.join(BASE_DIR, 'static'),'profiles')

destination = open(os.path.join(dir, myFile.name),

'wb+')

for chunk in myFile.chunks():

destination.write(chunk)

destination.close()

return HttpResponse('ok')

不过这个是通过输出request.FILES试出来的,不知道是否有更合适的方法。

总结

到此这篇关于Django接收照片储存文件的实例代码 的文章就介绍到这了,更多相关Django储存文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

本门课程重实战,将基础知识拆解到项目里,让你在项目情境里学知识。 这样的学习方式能让你保持兴趣、充满动力,时刻知道学的东西能用在哪、能怎么用。 平时不明白的知识点,放在项目里去理解就恍然大悟了。   一、融汇贯通 本视频采用了前后端分离的开发模式,前端使用Vue.js+Element UI实现了Web页面的呈现,后端使用PythonDjango框架实现了数据访问的接口,前端通过Axios访问后端接口获得数据。在学习完本章节后,真正理解前后端的各自承担的工作。   二、贴近实战 本系列课程为练手项目实战:学生管理系统v4.0的开发,项目包含了如下几个内容:项目的总体介绍、基本功能的演示、Vuejs的初始化、Element UI的使用、在Django中实现针对数据的增删改查的接口、在Vuejs中实现前端增删改查的调用、实现文件的上传、实现表格的分页、实现导出数据到Excel、实现通过Excel导入数据、实现针对表格的批量化操作等等,所有的功能都通过演示完成、贴近了实战   三、课程亮点 在本案例中,最大的亮点在于前后端做了分离,真正理解前后端的各自承担的工作。前端如何和后端交互   适合人群: 1、有Python语言基础、web前端基础,想要深入学习Python Web框架的朋友; 2、有Django基础,但是想学习企业级项目实战的朋友; 3、有MySQL数据库基础的朋友  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值