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中MySQLdb的事务处理功能
Sep 21 Python
Python使用getpass库读取密码的示例
Oct 10 Python
用matplotlib画等高线图详解
Dec 14 Python
python中将字典形式的数据循环插入Excel
Jan 16 Python
基于windows下pip安装python模块时报错总结
Jun 12 Python
对tf.reduce_sum tensorflow维度上的操作详解
Jul 26 Python
Django REST framework 分页的实现代码
Jun 19 Python
numpy 返回函数的上三角矩阵实例
Nov 25 Python
Python命令行click参数用法解析
Dec 19 Python
django从后台返回html代码的实例
Mar 11 Python
python 6行代码制作月历生成器
Sep 18 Python
详解pycharm连接远程linux服务器的虚拟环境的方法
Nov 13 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
PHP+JS+rsa数据加密传输实现代码
2011/03/23 PHP
php使用文本统计访问量的方法
2016/05/12 PHP
php使用json_decode后数字对象转换成了科学计数法的解决方法
2017/02/20 PHP
php基于PDO实现功能强大的MYSQL封装类实例
2017/02/27 PHP
textContent在Firefox下与innerText等效的属性
2007/05/12 Javascript
jquery鼠标滑过提示title具体实现代码
2013/08/06 Javascript
jquery中使用循环下拉菜单示例代码
2014/09/24 Javascript
jquery获取及设置outerhtml的方法
2015/03/09 Javascript
浅谈Node.js中的定时器
2015/06/18 Javascript
HTML页面,测试JS对C函数的调用简单实例
2016/08/09 Javascript
JS实现页面载入时随机显示图片效果
2016/09/07 Javascript
微信小程序 选项卡的简单实例
2017/05/24 Javascript
BootStrap给table表格的每一行添加一个按钮事件
2017/09/07 Javascript
原生JS实现日历组件的示例代码
2017/09/22 Javascript
Vue+jquery实现表格指定列的文字收缩的示例代码
2018/01/09 jQuery
在vue2.0中引用element-ui组件库的方法
2018/06/21 Javascript
微信小程序城市选择及搜索功能的方法
2019/03/22 Javascript
vue中多个倒计时实现代码实例
2019/03/27 Javascript
node.js中module模块的功能理解与用法实例分析
2020/02/14 Javascript
[02:43]DOTA2英雄基础教程 半人马战行者
2014/01/13 DOTA
Python读取图片EXIF信息类库介绍和使用实例
2014/07/10 Python
python中set常用操作汇总
2016/06/30 Python
Python实现随机生成有效手机号码及身份证功能示例
2017/06/05 Python
Python实现破解12306图片验证码的方法分析
2017/12/29 Python
对Python中DataFrame按照行遍历的方法
2018/04/08 Python
解决python写入mysql中datetime类型遇到的问题
2018/06/21 Python
Python3调用百度AI识别图片中的文字功能示例【测试可用】
2019/03/13 Python
用python实现一个简单计算器(完整DEMO)
2020/10/14 Python
python自动打开浏览器下载zip并提取内容写入excel
2021/01/04 Python
美国正宗奢华复古手袋、珠宝及配饰网站:What Goes Around Comes Around
2018/07/21 全球购物
下列程序在32位linux或unix中的结果是什么
2015/01/26 面试题
优秀求职信范文分享
2014/01/26 职场文书
家长对孩子评语
2014/01/30 职场文书
2014全国两会心得体会
2014/03/17 职场文书
中学生社区服务活动报告
2015/02/05 职场文书
不要在HTML中滥用div
2021/05/08 HTML / CSS