python diango_图解Python 【第十二篇】:Django 基础

本节内容一览表:

1217797-20171018101734646-1156206926.png

1217797-20171219144340928-1683770186.png

一、Django简介

1217797-20171219144856131-1270685772.png

1217797-20170929170228528-1916587286.png

1217797-20171219151311756-1456176391.png

1.web框架介绍

具体介绍Django之前,必须先介绍WEB框架等概念。

web框架: 别人已经设定好的一个web网站模板,你学习它的规则,然后“填空”或“修改”成你自己需要的样子。

一般web框架的架构是这样的:

948404-20160830212049246-1153317231.jpg

其它基于python的web框架,如tornado、flask、webpy都是在这个范围内进行增删裁剪的。

例如tornado用的是自己的异步非阻塞“wsgi”,

flask则只提供了最精简和基本的框架。

Django则是直接使用了WSGI,并实现了大部分功能。

2. MVC/MTV介绍

MVC百度百科:全名Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。

通俗解释:一种文件的组织和管理形式!不要被缩写吓到了,这其实就是把不同类型的文件放到不同的目录下的一种方法,然后取了个高大上的名字。当然,它带来的好处有很多,比如前后端分离,松耦合等等,就不详细说明了。

模型(model):定义数据库相关的内容,一般放在models.py文件中。

视图(view):定义HTML等静态网页文件相关,也就是那些html、css、js等前端的东西。

控制器(controller):定义业务逻辑相关,就是你的主要代码。

MTV: 有些WEB框架觉得MVC的字面意思很别扭,就给它改了一下。view不再是HTML相关,而是主业务逻辑了,相当于控制器。html被放在Templates中,称作模板,于是MVC就变成了MTV。这其实就是一个文字游戏,和MVC本质上是一样的,换了个名字和叫法而已,换汤不换药。

3.Django的MTV模型组织

目录分开,就必须有机制将他们在内里进行耦合。在Django中,urls、orm、static、settings等起着重要的作用。一个典型的业务流程是如下图所示:

948404-20160903111840215-2065765780.jpg

django工程主要py文件

文件

功能

urls.py

网址入口,关联到views中对于的函数

models.py

与数据库操作相关,建立应用数据模型

views.py

处理用户发出请求,从urls中对应过来,通过渲染templates中网页显示内容

settings.py

相关设置,包括数据库设置,邮件设置,静态文件配置等

forms.py

表单,用户在浏览器端提交的表单数据类

admin.py

后台代码,大部分已完成

Django 版本对应的 Python 版本:

Django 版本Python 版本

1.8

2.7, 3.2 , 3.3, 3.4, 3.5

1.9, 1.10

2.7, 3.4, 3.5

1.11

2.7, 3.4, 3.5, 3.6

2.0

3.5+

1217797-20170929165935137-1420032409.png

二、Django项目实例

1.Django的安装

http://www.runoob.com/django/django-install.html

http://www.runoob.com/django/django-first-app.html

http://www.cnblogs.com/feixuelove1009/p/5823135.html

2.创建django项目

2.1、用命令的方式是: python django-admin.py startproject 项目name

2.2、下面是用界面的方式:

在linux等命令行界面下,使用django提供的命令和vim也能进行项目开发。但是,这里推荐使用pycharm这个目前最好的python开发IDE

,它功能强大,界面友好。(下面所有的操作都在pycharm中进行。)

点击:file-->new project,出现下面的对话框。

948404-20160830221502371-1143625656.png

选择Django栏目,输入项目名称,这里采用国际惯例的mysite。选择python解释器版本,点击create创建。

Django将自动生成下面的目录结构:

948404-20160830221628136-832794323.png

与项目同名的目录中是配置文件,templates目录是html文件存放也就是MTV中的T。manage.py是django项目管理文件。

948404-20160830222155746-982749621.png

3. 创建APP

在每个django项目中可以包含多个APP,相当于一个大型项目中的分系统、子模块、功能部件等等,相互之间比较独立,但也有联系。

所有的APP共享项目资源。

在pycharm下方的terminal终端中输入命令:

python manage.py startapp cmdb

这样就创建了一个叫做cmdb的APP,django自动生成“cmdb”文件夹。

948404-20160830222336449-1279532630.png

4. 编写路由

路由都在urls文件里,它将浏览器输入的url映射到相应的业务处理逻辑。

简单的urls编写方法如下图:

948404-20160830222854183-1076810264.png

5. 编写业务处理逻辑

业务处理逻辑都在views.py文件里。

948404-20160830223018324-1725571647.png

通过上面两个步骤,我们将index这个url指向了views里的index()函数,它接收用户请求,并返回一个“hello world”字符串。

6. 运行web服务

现在我们已经可以将web服务运行起来了。

命令行的方式是:python manage.py runserver 127.0.0.1:8000

但在pycharm中,你可以这么干:

在上部工具栏中找到下面图示的图标。

948404-20160830223309683-1106014591.png

点击下拉箭头

948404-20160830223413558-354278015.png

点击edit configurations

948404-20160830223435824-1333880627.png

在host中填入:127.0.0.1   port中填入:8000

OK确定之后,点击绿色的三角,web服务就运行起来了。

948404-20160830223604433-2023847864.png

按图所示,自动跳转到浏览器程序界面。显示的却是下图的404页面:

948404-20160830223647074-1854088091.png

修改一下url,添加“/index”,就一切ok了!

948404-20160830223733636-402109128.png

至此,一个最简单的django编写的web服务就启动成功了。

7. 返回HTML文件

上面我们返回给用户浏览器的是什么?一个字符串!实际上这肯定不行,通常我们都是将html文件返回给用户。

下面,我们写这么一个index.html文件:

948404-20160830224345761-1370574663.png

再修改一下views文件:

948404-20160830224420636-441621765.png

为了让django知道我们的html文件在哪里,需要修改settings文件的相应内容。但默认情况下,它正好适用,你无需修改。

948404-20160830224615668-365627617.png

接下来,我们可以重新启动web服务。在浏览器刷新一下,你会看到带有样式的“hello world”。

注:这里有个小技巧,在多次频繁重启服务时,由于端口未释放的原因,容易启动不了服务,修改一下端口就OK了。

8. 使用静态文件

我们已经可以将html文件返还给用户了,但是还不够,前端三大块,html、css、js还有各种插件,它们齐全才是一个完整

的页面。在django中,一般将静态文件放在static目录中。接下来,在mysite中新建个static目录。

948404-20160830225314058-2019723535.png

你的CSS,JS和各种插件都可以放置在这个目录里。

为了让django找到这个目录,依然需要对settings进行配置:

948404-20160830225403886-2079870404.png

同样,在index.html文件中,可以引入js文件了:

948404-20160830225507996-2043334590.png

重新启动web服务,刷新浏览器,查看结果。

9. 接收用户发送的数据

上面,我们将一个要素齐全的html文件返还给了用户浏览器。但这还不够,因为web服务器和用户之间没有动态交互。

下面我们设计一个表单,让用户输入用户名和密码,提交给index这个url,服务器将接收到这些数据。

先修改index.html文件

948404-20160830225843168-1078788144.png

然后修改views.py文件

948404-20160830225931449-2031664798.png

此时 ,重启web服务时,会出错,因为django有一个跨站请求保护机制,我们在settings文件中将它关闭。

948404-20160830230032699-44609715.png

再次进入浏览器,刷新页面:

948404-20160830230139418-2016934265.png

输入点东西,然后我们在pycharm中可以看到相应的数据。

10. 返回动态页面

我们收到了用户的数据,但返回给用户的依然是个静态页面,通常我们会根据用户的数据,进行处理后在返回给用户。

这时候,django采用自己的模板语言,类似jinja2,根据提供的数据,替换掉html中的相应部分,详细语法入门后再深入学习。

先改造views.py文件:

948404-20160830230546340-963093019.png

再改造index.html文件:

948404-20160903111615121-1818501347.png

重启服务,刷新浏览器:

948404-20160830230649511-2067013295.png

可以看到,我们获得了用户实时输入的数据,并将它实时展示在了用户页面上,这是个不错的交互过程。

11. 使用数据库

流程走到这里,django的MTV框架基本已经浮出水面了,只剩下最后的数据库部分了。

上面我们虽然和用户交互得很好,但并没有保存任何数据,页面一旦关闭,或服务器重启,一切都将回到原始状态。

使用数据库是毫无疑问的,django通过自带的ORM框架操作数据库,并且自带轻量级的sqlite3数据库。下面我们来看一看:

首先是注册app:

948404-20160830231428449-1578630689.png

不注册它,你的数据库就不知道该给哪个app创建表。

然后我们在settings中,配置数据库相关的参数,如果使用自带的sqlite,不需要修改。

948404-20160830231601449-1743437183.png

再编辑models.py文件,也就是MTV中的M。

948404-20160830231652043-1110238877.png

这里我们创建了2个字段,分别保存用户的名字和密码。

接下来要在pycharm的teminal中通过命令创建数据库的表了。有2条命令,分别是:

python manage.py makemigrations

948404-20160830231822496-1448836608.png

再输入命令:python manage.py migrate

948404-20160830231916949-1344486910.png

修改views.py中的业务逻辑

948404-20160830231944605-2083069069.png

重启web服务后,刷新浏览器页面,之后和用户交互的数据都能保存到数据库中。任何时候都可以从数据库中读取数据,展示到页面上。

至此,一个要素齐全,主体框架展示清晰的django项目完成了,其实很简单是不是?

三、 Django总结

作为python必须web框架的Django,它的功能强大,内容全面,但同时也意味着限制颇多,灵活性低,可修改性差,这就是鱼和熊掌不可兼得了。我们学习Django,其实就是学习一个软件,要理解它的基本原理,把握它整体框架,牢记一些基本规则,剩下的就是不断深入细节,然后熟能生巧、经验多少的问题了,不存在多高深的不可掌握技术。

常用命令:

ContractedBlock.gif

ExpandedBlockStart.gif

1 #新建django project

2 django-admin.py startproject project-name3 #新建django app命令

4 django-admin.py startapp app-name (or) python manage.py startapp app-name5 #同步数据库

6 python manage.py syncdb7 #(django1.7.1及以上版本需要使用以下命令)

8 python manage.py makemigrations9 python manage.py migrate10 #运行django项目,不加port默认为8000

11 python manage.py runserver port12 #ex: python manage.py runserver 8080

13 #清空数据库

14 python manage.py flush15 #创建超级管理员

16 python manage.py createsuperuser17 #修改管理员密码

18 python manage.py changepassword username19 #导出数据

20 python manage.py dumpdata appname >appname.json21 #导入数据

22 python manage.py loaddata appname.json23 #进入django项目命令终端

24 python manage.py shell25 #进入数据库命令行

26 python manage.py dbshell

View Code

声明:

结合所学整理做次笔记,本文内容多出

http://www.cnblogs.com/feixuelove1009/p/5823135.html

http://code.ziqiangxuetang.com/django/django-tutorial.html

http://www.cnblogs.com/z1987/p/5490033.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值