• django learing day01


    一 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:调用这个函数来使用聚合。
    模型类关系:
            一对多关系
            多对多关系
            一对一关系
    学习,学习,学习! 学习是为了更好的未来,不要让别人瞧不起你,加油!!!
  • 相关阅读:
    bzoj 2832
    洛谷5月月赛
    P4705 玩游戏
    【bzoj4817】[Sdoi2017]树点涂色&&bzoj3779-重组病毒
    A
    P4715 「英语」Z 语言
    P4714 「数学」约数个数和
    P2860 [USACO06JAN]冗余路径Redundant Paths
    【BZOJ3252】攻略
    BZOJ 1706
  • 原文地址:https://www.cnblogs.com/yangyufeng/p/10439589.html
Copyright © 2020-2023  润新知