django 基础篇

jdango 简介:

一个可以使Web开发工作愉快并且高效的Web开发框架。 使用Django,使你能够以 小的代价构建和维护高质量的Web应用。

Python的WEB框架有Django、Tornado、Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了ORM、模型绑定、模板引擎、缓存、Session等诸多功能。

django 基础篇

django流程介绍

  著名的MVC模式:所谓MVC就是把web应用分为模型(M),控制器(C),视图(V)三层;他们之间以一种插件似的,松耦合的方式连接在一起。

  模型负责业务对象与数据库的对象(ORM),视图负责与用户的交互(页面),控制器(C)接受用户的输入调用模型和视图完成用户的请求。

  django 基础篇

Django的MTV模式本质上与MVC模式没有什么差别,也是各组件之间为了保持松耦合关系,只是定义上有些许不同,Django的MTV分别代表:

Model(模型):负责业务对象与数据库的对象(ORM)

Template(模版):负责如何把页面展示给用户

View(视图):负责业务逻辑,并在适当的时候调用Model和Template

此外,Django还有一个url分发器,它的作用是将一个个URL的页面请求分发给不同的view处理,view再调用相应的Model和Template

安装django

pip3 install django   # 默认安装 django 1.1 版本

基本配置

一、创建django程序

  首先在在终端上要先选择路径 在执行 创建django命令

  • 终端命令:django-admin startproject django_01     -- 创建django程序
  •   python manage.py startapp app01            --创建app 配置文件
  •   python manage.py makemigrations      -- 生成配置文件
  •   python manage.py migrate              -- 根据配置文件创建数据库相关功能
  • python manage.py runserver 127.0.0.1:8000   --执行django程序
  •   python manage.py createsuperuser        -- 创建超级用户

二、程序目录

django 基础篇

三、配置文件

1、数据库

DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME':'django_models',
'USER':'root',
'PASSWORD':'',
'HOST':'',
'PORT':'',
}
}
# 由于Django内部连接MySQL时使用的是MySQLdb模块,而python3中还无此模块,所以需要使用pymysql来代替

# 如下设置放置的与project同名的配置的 __init__.py文件中

import pymysql
pymysql.install_as_MySQLdb() 
 
2、模板:
TEMPLATE_DIRS = (
os.path.join(BASE_DIR,'templates'),
)

3、静态文件

  创建静态问价夹,  在settings 配置文件

STATICFILES_DIRS = (
os.path.join(BASE_DIR,'static'),
)

django views(视图函数)

django 基础篇

http请求中产生两个核心对象:

http请求:HttpRequest对象

http响应:HttpResponse对象

所在位置:django.http

之前我们用到的参数request就是HttpRequest    检测方法:isinstance(request,HttpRequest)

1 HttpRequest对象的属性:

django 基础篇

django 基础篇

path:       请求页面的全路径,不包括域名

method:     请求中使用的HTTP方法的字符串表示。全大写表示。例如

                   if  req.method=="GET":

                             do_something()

                   elseif req.method=="POST":

                             do_something_else()

GET:         包含所有HTTP GET参数的类字典对象

POST:       包含所有HTTP POST参数的类字典对象

             服务器收到空的POST请求的情况也是可能发生的,也就是说,表单form通过
HTTP POST方法提交请求,但是表单中可能没有数据,因此不能使用
if req.POST来判断是否使用了HTTP POST 方法;应该使用 if req.method=="POST" COOKIES: 包含所有cookies的标准Python字典对象;keys和values都是字符串。 FILES: 包含所有上传文件的类字典对象;FILES中的每一个Key都是<input type="file" name="" />标签中 name属性的值,FILES中的每一个value同时也是一个标准的python字典对象,包含下面三个Keys: filename: 上传文件名,用字符串表示
content_type: 上传文件的Content Type
content: 上传文件的原始内容 user: 是一个django.contrib.auth.models.User对象,代表当前登陆的用户。如果访问用户当前
没有登陆,user将被初始化为django.contrib.auth.models.AnonymousUser的实例。你
可以通过user的is_authenticated()方法来辨别用户是否登陆:
if req.user.is_authenticated();只有激活Django中的AuthenticationMiddleware
时该属性才可用 session: 唯一可读写的属性,代表当前会话的字典对象;自己有激活Django中的session支持时该属性才可用。

HttpResponse 对象属性

HttpRequest对象的方法:get_full_path(),   比如:http://127.0.0.1:8000/index33/?name=123 ,req.get_full_path()得到的结果就是/index33/?name=123

2、HttpResponse对象:

在HttpResponse对象上扩展的常用方法:页面渲染:render,render_to_response,

页面跳转:redirect

locals:   可以直接将函数中所有的变量传给模板

return HttpResponse('ASD')
return render_to_response('admin.html')
return render(request,'admin.html')
return redirect('/choutiadmin/login')

django 基础篇

django 基础篇

Django Models(模型)

 数据库配置  

1      django默认支持sqlite,mysql, oracle,postgresql数据库。

<1> sqlite

django默认使用sqlite的数据库,默认自带sqlite的数据库驱动

引擎名称:django.db.backends.sqlite3

     <2>mysql

引擎名称:django.db.backends.mysql

2    mysql驱动程序

MySQLdb(mysql python)

mysqlclient

MySQL

PyMySQL(纯python的mysql驱动程序)

3     在django的项目中会默认使用sqlite数据库,在settings里有如下设置:

django 基础篇

如果我们想要更改数据库,需要修改如下

django 基础篇

注意:NAME即数据库的名字,在mysql连接前该数据库必须已经创建,而上面的sqlite数据库下的db.sqlite3则是项目自动创建

USER和PASSWORD分别是数据库的用户名和密码。

设置完后,再启动我们的Django项目前,我们需要激活我们的mysql。

然后,启动项目,会报错:no module named MySQLdb

这是因为django默认你导入的驱动是MySQLdb,可是MySQLdb对于py3有很大问题,所以我们需要的驱动是PyMySQL

所以,我们只需要找到项目名文件下的__init__,在里面写入:

                 import pymysql

                 pymysql.install_as_MySQLdb()

问题就解决了! 这时就可以正常启动了。    但此时数据库内并没有内容,我们需要做数据库的同步:

django 基础篇

为了更好的查询修改数据库,我们可以不使用Navicate,而是利用pycharm的Database

django 基础篇

然后 ,安装MySQL的驱动(driver),这里需要创建一个密码(我的是123)安装成功后,

django 基础篇

填入数据库的名字,mysql的用户名和密码,然后就可以进行连接了

django 基础篇

成功后点击右下角的apply和OK。

这是你就可以看到数据库里的表和内容了:

django 基础篇

是不是很方便呢?

如果你用的是sqlite数据库就更简单了,安装完驱动后,直接将sqlite拖动到Database就可以了:

django 基础篇

参考博文地址:了解更多请点这里    了解更多请点这里

上一篇:DropDownList中显示无限级树形结构


下一篇:hdfs文件按修改时间下载