目录
1.Django项目的创建与介绍
2.Django应用的创建与介绍
3.Django启动项目
4.Django生命周期
5.Django视图三件套
6.Django静态文件(css)
7.Django请求数据
8.配置Mysql完成数据迁移
9.Django orm简介
10.Django orm实操
11.单表ORM记录的增删改查
12.数据的增删改查
1.Django项目的创建与介绍
'''
安装:pip3 install django==2.2.19
查看版本号:django-admin --version
新建项目:1.前往目标目录 2.django-admin startproject proj_name
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
'''
2.Django应用的创建与介绍
'''
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:执行相应的逻辑代码模块
'''
3.Django启动项目
# 默认8000端口
python3 manage.py runserver 127.0.0.1:8801
4.Django生命周期
'''
1.浏览器发送请求
2.wsgi服务器接收到请求,将请求解析交给Django
3.Django中间件过滤请求信息,交给路由
4.路由完成业务逻辑的分发,到指定app下views中指定的视图函数
5.视图函数完成具体的业务逻辑,返回响应结果
6.将处理结果通过服务器返回给浏览器
'''
5.Django视图三件套
# views.py配置
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/')
6.Django静态文件(css)
1.settings.py中配置
STATIC_URL = '/static/' # 静态文件请求根路由
STATICFILES_DIRS = [
os.path.join(BASE_DIR, 'static') # 静态文件检索的文件夹
]
2.在项目根目录下创建static文件夹
3.静态文件就放在static根目录或子目录下
4.获取静态文件:/static/目标文件(可以包含static子文件夹路径)
5.进阶操作
STATIC_URL = '/static/' # 接口前缀
"""
如果你想要访问静态文件资源,那么必须以static开头
<script src="/static/bootstrap-3.3.7-dist/js/bootstrap.min.js"></script>
你书写了接口前缀之后 就拥有了访问下列列表中所有文件夹内部资源的权限
"""
# 静态文件配置
STATICFILES_DIRS = [
os.path.join(BASE_DIR,'static'),
os.path.join(BASE_DIR,'static1'),
os.path.join(BASE_DIR,'static2'),
]
6.动态解析
{% load static %}
<link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}">
<script src="{% static 'bootstrap-3.3.7-dist/js/bootstrap.min.js' %}"></script>
7.Django请求数据
请求路径:
1.空着:默认向当前路径发送请求
2.http://127.0.0.1:8801/testAction/:向testAction路径发送请求
3./testAction/: 向testAction路径发送请求(推荐)
在视图函数中
请求方式:request.method
GET请求获取数据:request.GET.get('key', None) # 当key不存在,用None替换
POST请求获取数据:request.POST.get('key', None) # 当key不存在,用None替换
request对象方法
request.method
获取当前请求的请求方法并且结果是一个纯大写的字符串类型
request.POST # 直接看成是字典即可
获取用户提交post请求过来的基本数据(不包含文件)
get() # 获取列表最后一个元素
getlist() # 获取整个列表
request.GET # 直接看成是字典即可
获取url问好后面的数据
get() # 获取列表最后一个元素
getlist() # 获取整个列表
request.FILES # 直接看成是字典即可
获取用户上传的文件数据
'''form表单如果需要携带文件数据 那么要添加参数
<form action="" method="post" enctype="multipart/form-data">
'''
get() # 获取列表最后一个元素
getlist() # 获取整个列表
"""
视图函数书写格式
def login(request):
if request.method == 'POST':
return HttpResponse("我很气愤")
return render(request,'login.html')
"""
8.配置Mysql完成数据迁移
1.在settings.py配置Mysql数据库信息
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': '数据库名',
'HOST': '127.0.0.1',
'PORT': 3306,
'USER': 'root',
'PASSWORD': '123'
'CHARSET': 'utf8'
}
}
2. 1.1.x版本在项目或应用的init文件中修改连接数据库的模块为pymysql
import pymysql
pymysql.install_as_MySQLdb()
3. 2.2.x版本不需要配置 安装mysqlclient包
4.在项目目录下,执行(生成迁移数据,没有映射到数据库):python3 manage.py makemigrations
5.将迁移数据映射到数据库:python3 manage.py migrate
9.django orm简介
"""
orm:对象关系映射
"""
orm目的就是为了能够让不懂SQL语句的人通过python面向对象的知识点也能够轻松自如的操作数据库
类 >>> 表
对象 >>> 表里面的数据
对象点属性 >>> 字段对应的值
# 缺陷:sql封装死了 有时候查询速度很慢
10.Django orm实操
1.我们的模型类需要写在应用下的models.py文件中
class User(models.Model):
# id int primary key auto_increment
id = models.AutoField(primary_key=True)
# name varchar(32)
name = models.CharField(max_length=32) # CharField必须要加max_length参数
# age int
age = models.IntegerField()
****************************************************************************
2.数据库迁移命令
1.将数据库修改操作先记录到小本本上(对应应用下的migrations文件夹)
python3 manage.py makemigrations
2.真正的执行数据库迁移操作
python3 manage.py migrate
# 只要动了models.py中跟数据库相关的代码就必须重新执行上述两条命令
****************************************************************************
3.针对主键字段
class User1(models.Model):
# 如果你不指定主键 那么orm会自动帮你创建一个名为id的主键字段
# 如果你想让主键字段名不叫id 叫uid、sid、pid等则需要自己手动指定
username = models.CharField(max_length=32)
11.单表ORM记录的增删改查
# 增
pwd = models.IntegerField('密码',null=True) # 该字段可以为空
is_delete = models.IntegerField(default=0) # 默认值
# 改
直接改代码然后执行数据库迁移命令即可
# 删
注释掉代码然后执行数据库迁移命令即可
12.数据的增删改查
# 在views.py 下操作
from app03 import models
# 1.查询数据
# select * from user where name=username;
user_obj = models.User.objects.filter(name=username).first()
# 2.添加数据
# insert into user(name,pwd) values(username,password);
models.User.objects.create(name=username,pwd=password)
# 3.查询所有的数据
# select * from user;
models.User.objects.all() # [obj1,obj2,obj3,obj4]
# 4.修改数据
models.User.objects.filter(id=edit_id).update(name=username,pwd=password)
edit_obj.name = username
edit_obj.pwd = password
edit_obj.save()
# 5.删除数据
models.User.objects.filter(id=delete_id).delete()
网友评论