摘要:背景介绍在的官网上有专门介绍如何处理文件上传的文档,其中说到了如何利用来处理文件上传的场景。但是,在中最快速的开发方式是利用来进行开发。上面用到了动态的,对应每个都提供不同的上传路径。在实际的使用中,可以针对于自己的应用场景选择。
背景介绍
在Django的官网上有专门介绍如何处理文件上传的文档,其中说到了如何利用model来处理文件上传的场景。但是,在Django中最快速的开发方式是利用class-based views来进行开发。所以,我自己整理了一下如何利用class-based views来处理文件上传的场景,特此记录。
既然是数据驱动的web,自然先要有model。
from django.db import models from django.contrib.auth.models import User from django.conf import settings import os _roles_path = os.path.join(_base_path, "roles") def var_dir(instance, filename): return os.path.join(_roles_path, instance.name, "vars", filename) def task_dir(instance, filename): return os.path.join(_roles_path, instance.name, "tasks", filename) class Roles(models.Model): id = models.AutoField(primary_key=True) name = models.CharField(max_length=50) creator = models.ForeignKey(User) createDatetime = models.DateTimeField(auto_now_add=True) directory = models.FilePathField(path=_roles_path, match="*.yml", recursive=True, max_length=200) tasks = models.FileField(upload_to=task_dir, blank=False) vars = models.FileField(upload_to=var_dir) def __unicode__(self): return u"%s" % self.name
上面用到了动态的upload_to,对应每个FileField都提供不同的上传路径。因为upload_to可以接受一个callable的对象,所以我尝试过把lambda赋值给upload_to,但是在测试中发现,给upload_to赋值为lambda表达式是会报错的ValueError: Cannot serialize function: lambda。应该可以尝试利用闭包的方式来给upload_to赋值,以解决多种动态路径的需求。
经过后续的测试发现,闭包也是不支持的
def _roles_subdir(roles_path, subdir): def wrapper(instance, filename): return os.path.join(roles_path, instance.name, subdir, filename) return wrapper
viewPlease note that due to Python 2 limitations, you cannot serialize unbound method functions (e.g. a method declared
and used in the same class body). Please move the function into the main module body to use migrations.
For more information, see
https://docs.djangoproject.com/en/1.7/topics/migrations/#serializing-values
本例中使用Django提供的CreateView。在实际的使用中,可以针对于自己的应用场景选择CreateView、UpdateView。
from django.views.generic.edit import FormView, CreateView from django.views.decorators.csrf import csrf_exempt from django.core.urlresolvers import reverse_lazy class UploadRolesFormView(CreateView): template_name = "app/upload_roles.html" model = Roles fields = ["name", "tasks", "vars"] success_url = reverse_lazy("app:index") #临时去掉CSRF保护,千万别学我! @csrf_exempt def dispatch(self, request, *args, **kwargs): return super(UploadRolesFormView, self).dispatch(request, *args, **kwargs) #override def form_valid(self, form): #在form中加入user对象存入model form.instance.creator = self.request.user return super(UploadRolesFormView, self).form_valid(form)template
urlupload
在app的urls.py中加入一条对应的url规则:
url(r"^upload/$", views.UploadRolesFormView.as_view(), name="rolesUpload"),
这样,就可以利用Django最方便的class-based views开处理文件上传的场景了。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/37644.html
摘要:既然是数据驱动的,首先就必须要有数据。也符合它用于查看数据的需求。说明模板中的对象就是从中取出的数据。以的类型存储着所有数据。修改视图接下来就是第二类修改视图了。其中的会将中的该字段设为类型而则是带有清除文件功能的类型。 最近在学习Django,官方文档介绍地十分详细。但是大而全就难免会有些不够速成,和我们这个浮躁的互联网时代格格不入,所以我就整理了这个文档。就像coolshell说的...
摘要:官网地址个人学习笔记四我们也能够使用来编写我们的,而不是基于正如我们所看到的,这是一个强大的模式,它使我们的功能能够复用,并保持我们的代码整洁。检索,更新或者删除一个实例。接下来将展示使用来组成我们的。 (官网地址)[django rest framework个人学习笔记(四)————Tutorial] Class-based views 我们也能够使用class-based view...
摘要:官网地址个人学习笔记四我们也能够使用来编写我们的,而不是基于正如我们所看到的,这是一个强大的模式,它使我们的功能能够复用,并保持我们的代码整洁。检索,更新或者删除一个实例。接下来将展示使用来组成我们的。 (官网地址)[django rest framework个人学习笔记(四)————Tutorial] Class-based views 我们也能够使用class-based view...
摘要:官网地址个人学习笔记四我们也能够使用来编写我们的,而不是基于正如我们所看到的,这是一个强大的模式,它使我们的功能能够复用,并保持我们的代码整洁。检索,更新或者删除一个实例。接下来将展示使用来组成我们的。 (官网地址)[django rest framework个人学习笔记(四)————Tutorial] Class-based views 我们也能够使用class-based view...
摘要:为了避免做广告的嫌疑,以后会把熙鱿记个字去掉了。在和用户注册的账户功能,比如登陆注册退出修改密码等都在里实现。第二个参数要跳转的路径,如果没有第二个参数则默认跳转到登陆页面里添加 为了避免做广告的嫌疑,以后会把熙鱿记3个字去掉了。 现在我们完善登陆和注册功能。 首先,我们要为站点创建一个超级用户python manage.py createsuperuser然后根据命令行提示输入用...
阅读 3498·2021-09-10 10:51
阅读 2471·2021-09-07 10:26
阅读 2450·2021-09-03 10:41
阅读 774·2019-08-30 15:56
阅读 2852·2019-08-30 14:16
阅读 3457·2019-08-30 13:53
阅读 2036·2019-08-26 13:48
阅读 1884·2019-08-26 13:37