Python+django实现简单的文件上传


Posted in Python onAugust 17, 2016

今天分享一下Django实现的简单的文件上传的小例子。

步骤
 •创建Django项目,创建Django应用
 •设计模型
 •处理urls.py 以及views.py
 •设计模板,设计表单
 •运行项目,查看数据库

下面我们就一起来分别完成每一个小部分吧。

创建项目和应用

django-admin startproject Django_upload

django-admin startapp app

添加一个名为upload的目录,待会要用哦。

然后记得在settings.py 中的INSTALLED_APPS中加上'app',。注意那个小逗号就行了~~

设计模型

上传文件需要知道是谁上传的,上传了什么。所以我们的 模型很简单,一个用户名,一个文件名即可。如下app.models.py

from __future__ import unicode_literals

from django.db import models

# Create your models here.

# User CLass for user,username and userimg path
class NormalUser(models.Model):
  username = models.CharField(max_length=30)
  headImg = models.FileField(upload_to='./upload')

  def __unicode__(self):
    return self.username

  class Meta:
    ordering = ['username']

模型创建完成了,接下来我们就赶紧同步一下数据库吧。命令很简单,由于我的Django版本是1.9.6的, 所以原来的

python manage.py syncdb 不能用了 

我们可以使用下面的命令来代替

python manage.py makemigrations

python manage.py migrate

urls.py 以及 views.py

这两个文件就是为了实现MVC模型的V,C而存在的。
views.py 如下:

from django.shortcuts import render,render_to_response
from django import forms
from django.http import HttpResponse
from app.models import *
# Create your views here.

class NormalUserForm(forms.Form):
  username = forms.CharField()
  headImg = forms.FileField()


def registerNormalUser(request):
  if request.method == "POST":
    uf = NormalUserForm(request.POST,request.FILES)
    if uf.is_valid():
      # get the info of the form
      username = uf.cleaned_data['username']
      headImg = uf.cleaned_data['headImg']
      # write in database
      normalUser = NormalUser()
      normalUser.username = username
      normalUser.headImg = headImg
      normalUser.save()
      return HttpResponse('Upload Succeed!')
  else:
    uf = NormalUserForm()
  return render(request,'register.html',{'uf':uf})

urls.py

"""Django_upload URL Configuration

The `urlpatterns` list routes URLs to views. For more information please see:
  https://docs.djangoproject.com/en/1.9/topics/http/urls/
Examples:
Function views
  1. Add an import: from my_app import views
  2. Add a URL to urlpatterns: url(r'^$', views.home, name='home')
Class-based views
  1. Add an import: from other_app.views import Home
  2. Add a URL to urlpatterns: url(r'^$', Home.as_view(), name='home')
Including another URLconf
  1. Import the include() function: from django.conf.urls import url, include
  2. Add a URL to urlpatterns: url(r'^blog/', include('blog.urls'))
"""
from django.conf.urls import url
from django.contrib import admin
from app.views import *
urlpatterns = [
  url(r'^admin/', admin.site.urls),
  url(r'^register/$',registerNormalUser),
]

一般来说我们会创建一个超级管理员,命令如下:

python manage.py createsuperuser

然后按照相应的提示进行创建就可以了。 

设计模板以及表单

其实刚才就可以在views.py中看到一个为NormalUserForm的类,其存在的意义就是方便从request中取得我们需要的表单数据。而且,恐怕你也注意到了,NormalUserForm的字段和NormalUser模型是一样的呢。各中哲理自己品味吧 :-)

templates/register.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Register</title>
</head>
<body>
<h2 align="center">Register</h2>

<form method="POST" enctype="multipart/form-data">
  {% csrf_token %}
  {{ uf.as_p }}
  <input type="submit" value="Submit">
</form>


</body>
</html>

这里面比较重要的地方有三点:
 •<form method="POST" enctype="multipart/form-data">: 表单特定的格式,注意上传数据的时候把enctype明确就可以

 •{% csrf_token %}: 跨域请求,我们需要在表单标签的内部加上这个模板标签,而且要在views.py中配合render而不是render_to_response来实现

 •{{ uf.as_p }}: 使用.as_p 方式的话,django就会按照默认的样式在模板页面输出表单的所有的字段。

 调试,开启应用

好了,大部分的任务都做好了,下面就打开我们的开发服务器来验证一下吧。

python manage.py runserver

打开浏览器输入http://127.0.0.1:8000/register

然后按要求填写表单,就可以了。彩蛋就是加上了is_valid()方法的views.py会自动的帮助我们对表单数据字段进行验证!

打开我们的数据库管理软件,就会发现里面存储的只是路径,而并不是真正的数据。这也体现了大数据存储的核心理念了。点击upload目录,发现文件确实上传成功了!

总结

今天的这个小例子虽然很简单,但是里面也有很多值得我们推敲的地方,我的收获如下。
 •使用models.FileField()实现文件上传组件

 •对应模型添加一个表单类,字段相同。这样对于表单数据的获取会更加更加的方便。uf = NormalUserForm(request.POST,request.FILES)。

 •模板界面表单enctype格式,以及.as_p方式的在html页面上的表单输出

就是这样了!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python根据区号生成手机号码的方法
Jul 08 Python
python连接数据库的方法
Oct 19 Python
python 3利用Dlib 19.7实现摄像头人脸检测特征点标定
Feb 26 Python
数组保存为txt, npy, csv 文件, 数组遍历enumerate的方法
Jul 09 Python
pytorch: tensor类型的构建与相互转换实例
Jul 26 Python
Python PyAutoGUI模块控制鼠标和键盘实现自动化任务详解
Sep 04 Python
python+splinter自动刷新抢票功能
Sep 25 Python
python实现嵌套列表平铺的两种方法
Nov 08 Python
python write无法写入文件的解决方法
Jan 23 Python
详解python深浅拷贝区别
Jun 24 Python
Tensorflow中批量读取数据的案列分析及TFRecord文件的打包与读取
Jun 30 Python
python 使用递归的方式实现语义图片分割功能
Jul 16 Python
Python Django使用forms来实现评论功能
Aug 17 #Python
小小聊天室Python代码实现
Aug 17 #Python
python如何在终端里面显示一张图片
Aug 17 #Python
动感网页相册 python编写简单文件夹内图片浏览工具
Aug 17 #Python
Python入门教程之运算符与控制流
Aug 17 #Python
python 循环while和for in简单实例
Aug 16 #Python
Python自动化测试ConfigParser模块读写配置文件
Aug 15 #Python
You might like
第十三节--对象串行化
2006/11/16 PHP
php将gd生成的图片缓存到memcache的小例子
2013/06/05 PHP
Yii2创建控制器(createController)方法详解
2016/07/23 PHP
PHP函数用法详解【初始化、嵌套、内置函数等】
2020/06/02 PHP
如何判断图片地址是否失效
2007/02/02 Javascript
在IE和VB中支持png图片透明效果的实现方法(vb源码打包)
2011/04/01 Javascript
JS实现一键回顶功能示例代码
2013/10/28 Javascript
jQuery中Ajax的load方法详解
2015/01/14 Javascript
jQuery实用技巧必备(中)
2015/11/03 Javascript
浅析Bootstrip的select控件绑定数据的问题
2016/05/10 Javascript
Three.js快速入门教程
2016/09/09 Javascript
angular+ionic 的app上拉加载更新数据实现方法
2017/01/16 Javascript
从零学习node.js之文件操作(三)
2017/02/21 Javascript
详解ES6语法之可迭代协议和迭代器协议
2018/01/13 Javascript
详解webpack多页面配置记录
2018/01/22 Javascript
深入浅析var,let,const的异同点
2018/08/07 Javascript
JavaScript数组特性与实践应用深入详解
2018/12/30 Javascript
layui 数据表格复选框实现单选功能的例子
2019/09/19 Javascript
[01:48]2018DOTA2亚洲邀请赛主赛事第二日五佳镜头 VG完美团战逆转TNC
2018/04/05 DOTA
Python2.x版本中cmp()方法的使用教程
2015/05/14 Python
利用TensorFlow训练简单的二分类神经网络模型的方法
2018/03/05 Python
python3使用flask编写注册post接口的方法
2018/12/28 Python
django配置连接数据库及原生sql语句的使用方法
2019/03/03 Python
python实现WebSocket服务端过程解析
2019/10/18 Python
DJANGO-URL反向解析REVERSE实例讲解
2019/10/25 Python
CSS3悬停效果案例应用
2012/11/21 HTML / CSS
世界领先的高品质定制产品平台:Zazzle
2017/07/23 全球购物
蔻驰法国官网:COACH法国
2018/11/14 全球购物
商务会议邀请函
2014/01/09 职场文书
优秀班组长事迹
2014/05/31 职场文书
小学生我的梦想演讲稿
2014/08/21 职场文书
在教室放鞭炮的检讨书
2014/09/28 职场文书
平遥古城导游词
2015/02/03 职场文书
讲座新闻稿
2015/07/18 职场文书
三好学生竞选稿
2015/11/21 职场文书
PostgreSQL 插入INSERT、删除DELETE、更新UPDATE、事务transaction
2022/04/12 PostgreSQL