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