Django 一

作者: 吃可爱长大鸭 | 来源:发表于2021-04-15 10:28 被阅读0次

目录

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()

相关文章

网友评论

    本文标题:Django 一

    本文链接:https://www.haomeiwen.com/subject/mncdlltx.html