一 Django项目创建与介绍
安装: pip3 install django== 1.11.x (x代表版本号) 查看版本号: django-admin --version 新建项目: 1.前往目标目录 2.django-admin startproject 项目名称 proj_name:项目目录,包含项目最基本的一些配置 -- __init__.py:模块的配置文件 -- settings.py:配置总文件 -- urls.py:url配置文件,django项目中的所有页面都需要对其配置url地址 -- wsgi.py:(web server gateway interface),服务器网关接口,python应用与web服务器直接通信的接口 templates:模板文件夹,存放html文件的(页面),支持使用Django模板语言(DTL),也可以使用第三方(jinja2) manage.py:项目管理器,与项目交互的命令行工具集的入口,查看支持的所有命令python3 manage.py
二 应用的创建与介绍
''' 1.Django是面向应用开发,在应用中完成具体的业务逻辑 2.什么是应用app: 就好比项目中的一个功能模块,一个项目可以拥有多个功能模块,但至少得有一个,Django称之为app 3.如何创建app(在项目目录下):python3 manage.py startapp app01 migrations:数据迁移(移植)模块,内容都是由Django自动生成 -- __init__.py __init__.py admin.py:应用的后台管理系统配置 apps.py:django 1.9后,本应用的相关配置 models.py:数据模型模块,使用ORM框架,类似于MVC模式下的Model层 tests.py:自动化测试模块,可以写自动化测试脚本 views.py:执行相应的逻辑代码模块 '''
三 启动项目
终端: python3 manage.py runserver 127.0.0.1:8801
四 django的生命周期
1. 浏览器发送请求 2. wsgi服务器接收到请求,将请求解析交给django 3.Django中间件过滤请求信息,交给路由 4.路由完成业务逻辑的分发,到指定app下views中指定的视图函数 5.视图函数完成具体的业务逻辑,返回响应结果 6.将处理结果通过服务器返回给浏览器
五 django三件套
from django.shortcuts import HttpResponse, render, redirect # 返回基本信息 def action1(request): return HttpResponse("基础信息") # 返回HTML网页 def action2(request): return render(request, 'template_page.html', {k:v}) # 重定向 def action3(request): return redirect('/index/')
六 静态文件
1.在settings.py中配置 STATIC_URL = '/static/' # 静态文件请求根路由 STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static') # 静态文件检索的文件夹 ] 2.在项目根目录下创建static文件夹 3.静态文件就放在static根目录或子目录下 4.获取静态文件:/static/目标文件(可以包含static子文件夹路径)
七 请求及数据
请求路径: 1.空着:默认向当前路径发送请求 2.http://127.0.0.1:8801/testAction/:向testAction路径发送请求 3./testAction/: 向testAction路径发送请求(推荐) '''
形式: scheme://host[:port#]/path/…/[?query-string][#anchor]
scheme:协议(例如:http, https, ftp)
host:服务器的IP地址或者域名
port:服务器的端口(如果是走协议默认端口,80 or 443)
path:访问资源的路径
query-string:参数,发送给http服务器的数据
anchor:锚(跳转到网页的指定锚点位置)
http://localhost:8000/file/part01/1.2.html
''' 在视图函数中 请求方式:request.method GET请求获取数据:request.GET.get('key', None) # 当key不存在,用None替换 POST请求获取数据:request.POST.get('key', None) # 当key不存在,用None替换
八 配置数据库并完成迁移
1.在settings.py配置Mysql数据库信息 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'dg2', 'HOST': '127.0.0.1', 'PORT': 3306, 'USER': 'root', 'PASSWORD': 'root' } } 2.在项目或应用的init文件中修改连接数据库的模块为pymysql import pymysql pymysql.install_as_MySQLdb() 3.在项目目录下,执行(生成迁移数据,没有映射到数据库):python3 manage.py makemigrations 4.将迁移数据映射到数据库:python3 manage.py migrate
九 单表ORM记录的增删改查
# 增 User.objects.create(usr='abc', pwd='123') # 第一种方式 user = User(usr='owen', pwd='123') user.save() # 第二种方式 # 删 User.objects.filter(id=1).delete() # 改 User.objects.filter(pwd='123').update(pwd='000') # 查 User.objects.filter(pwd='000').all() User.objects.filter(pwd='000').first()
Django中models利用orm对Mysql多表查询语句
字段查询 all(): 返回模型类对用表中的所有数据 get(): 返回表格中的一条数据, MultipleObjectsReturned: 如果查到多条则抛出异常 DoesNotExist: 查询不到数据,则抛异常 filter(): 参数写查询条件,返回满足条件的QuerySet集合数据 查询格式: User.object.filter(id=id) [此处是模型类属性名,不是表中的字段名] 模糊查询: 空查询 where 字段名 isnull 范围查询 where id in (1,3,5) 比较查询 gt lt(less than) gte(equal) lte 日期查询 exclude:返回不满足条件的数据。 F对象:作用:用于类属性之间的比较条件。 Q对象:作用:用于查询时的逻辑条件。可以对 Q 对象进行&|~操作 作用:对查询结果进行排序 聚合函数: 作用:对查询结果进行聚合操作 aggregate:调用这个函数来使用聚合。 模型类关系: 一对多关系 多对多关系 一对一关系