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 os模块常用命令介绍
Nov 03 Python
python爬虫框架scrapy实现模拟登录操作示例
Aug 02 Python
Python实现的简单线性回归算法实例分析
Dec 26 Python
python 一篇文章搞懂装饰器所有用法(建议收藏)
Aug 23 Python
解决Django提交表单报错:CSRF token missing or incorrect的问题
Mar 13 Python
python+adb+monkey实现Rom稳定性测试详解
Apr 23 Python
Python调用.net动态库实现过程解析
Jun 05 Python
Python实现封装打包自己写的代码,被python import
Jul 12 Python
python实现梯度下降算法的实例详解
Aug 17 Python
超级实用的8个Python列表技巧
Aug 24 Python
python tqdm实现进度条的示例代码
Nov 10 Python
Python读写yaml文件
Mar 20 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
上海永华YH-R296(华普R-96)12波段立体声收音机的分析和打理
2021/03/02 无线电
PHP5.0对象模型探索之抽象方法和抽象类
2006/09/05 PHP
一个分页的论坛
2006/10/09 PHP
PHP使用SOAP调用.net的WebService数据
2013/11/12 PHP
php出现web系统多域名登录失败的解决方法
2014/09/30 PHP
PHP计算指定日期所在周的开始和结束日期的方法
2015/03/24 PHP
php实现将wav文件转换成图像文件并在页面中显示的方法
2015/04/21 PHP
PHP实现PDO操作mysql存储过程示例
2019/02/13 PHP
js下通过prototype扩展实现indexOf的代码
2010/12/08 Javascript
jQuery帮助之筛选查找 children([expr])
2011/01/31 Javascript
jQuery.autocomplete 支持中文输入(firefox)修正方法
2011/03/10 Javascript
web基于浏览器的本地存储方法应用
2012/11/27 Javascript
FF IE浏览器修改标签透明度的方法
2014/01/27 Javascript
jquery获取多个checkbox的值异步提交给php
2015/07/07 Javascript
JavaScript基于DOM操作实现简单的数学运算功能示例
2017/01/16 Javascript
详解Vue路由History mode模式中页面无法渲染的原因及解决
2017/09/28 Javascript
VUE重点问题总结
2018/03/19 Javascript
微信小程序多音频播放进度条问题
2018/08/28 Javascript
如何将百度地图包装成Vue的组件的方法步骤
2019/02/12 Javascript
Vue实现表格批量审核功能实例代码
2019/05/28 Javascript
一篇文章带你从零快速上手Rollup
2020/09/07 Javascript
ES6的循环与可迭代对象示例详解
2021/01/31 Javascript
Python爬虫框架Scrapy安装使用步骤
2014/04/01 Python
python实现多线程暴力破解登陆路由器功能代码分享
2015/01/04 Python
Django Rest framework频率原理与限制
2019/07/26 Python
Python 实现将numpy中的nan和inf,nan替换成对应的均值
2020/06/08 Python
python 中的9个实用技巧,助你提高开发效率
2020/08/30 Python
Python中的None与 NULL(即空字符)的区别详解
2020/09/24 Python
接口自动化多层嵌套json数据处理代码实例
2020/11/20 Python
python中函数返回多个结果的实例方法
2020/12/16 Python
浅析python实现动态规划背包问题
2020/12/31 Python
Ibatis的核心配置文件都有什么
2014/09/08 面试题
九年级数学教学反思
2014/02/02 职场文书
2014年收银工作总结
2014/11/13 职场文书
优秀共产党员主要事迹材料
2015/11/05 职场文书
Python实现Excel文件的合并(以新冠疫情数据为例)
2022/03/20 Python