zoukankan      html  css  js  c++  java
  • DJango入门

    DJango介绍

    dJango是python三大主流web框架之一。

    特点:大而全,自带的功能特别特别特别的多,类似于航空母舰。

    不足之处:有时候过于笨重。

    web框架三大部分及dJango对应详情:

    web框架 DJango
    socket部分 用别人的(wsgiref)
    路由与视图函数的对应关系(路由匹配) 用自己的
    模板语法 用自己的(没jinja2好用)

    DJango注意事项:

    如何让你的计算机能够正常的启动DJango项目

      1.计算机的名称不能有中文

      2.一个pycharm窗口只开一个项目
      3.项目里面所有的文件也尽量不要出现中文
      4.python解释器尽量使用3.4~3.6之间的版本
    (如果你的项目报错 你点击最后一个报错信息
    去源码中把逗号删掉)

    DJango版本问题

      1.X 2.X 3.X(直接忽略)

      1.X和2.X本身差距也不大 我们讲解主要以1.X为例 会讲解2.X区别

      公司之前用的1.8 满满过渡到了1.11版本 有一些项目用的2.0

    DJango安装

    pip3.6 install django==1.11.11 -i http://pypi.douban.com/simple --trusted-host pypi.douban.com
    

    如果已经安装了其他版本,无需自己卸载,直接重新装 会自动卸载安装新的

    如果报错,看看是不是timeout,如果是,那么只是网速波动,重新安装即可

    验证是否安装成功的方式1
    终端输入django-admin看看有没有反应

    DJango基本操作

    命令行操作:

    1.创建django项目

    django-admin startproject mysite
    

    你可以先切换到对应的D盘 然后再创建
    mysite文件夹
    manage.py
    mysite文件夹
    init.py
    settings.py
    urls.py
    wsgi.py

    2.启动django项目

    注意:一定要先切换到项目目录下

    cd /mysite
    python3 manage.py runserver
    

    3.创建应用

    """
    Next, start your first app by running python manage.py startapp [app_label].
    """
    	python manage.py startapp XXXX
        应用名应该做到见名知意
          user
          order
          web
          ...
    

    pycharm操作

    1 new project 选择左侧第二个django即可

    2 启动

      用命令行启动
      点击绿色小箭头即可

    3 创建应用

      1.pycharm提供的终端直接输入完整命令
      2.pycharm
        tools
        run manage.py task提示(前期不要用 给我背完整命令)

    4 修改端口号以及创建server

      edit confi....

    命令行与pycharm创建的区别

    # 1 命令行创建不会自动有templatew文件夹 需要你自己手动创建而pycharm会自动帮你创建并且还会自动在配置文件中配置对应的路径
    # pycharm创建
    TEMPLATES = [
        {
            'BACKEND': 'django.template.backends.django.DjangoTemplates',
            'DIRS': [os.path.join(BASE_DIR, 'templates')]
    ]
    # 命令行创建
    TEMPLATES = [
        {
            'BACKEND': 'django.template.backends.django.DjangoTemplates',
            'DIRS': [],
    ]
    """
    也就意味着你在用命令创建django项目的时候不单单需要创建templates文件夹还需要去配置文件中配置路径
    'DIRS': [os.path.join(BASE_DIR, 'templates')]
    """
    

    应用

    """
    django是一款专门用来开发app的web框架
    
    django框架就类似于是一所大学(空壳子)
    app就类似于大学里面各个学院(具体功能的app)
    	比如开发淘宝
    		订单相关
    		用户相关
    		投诉相关
    		创建不同的app对应不同的功能
    	
    	选课系统
    		学生功能
    		老师功能
    
    一个app就是一个独立的功能模块
    """
    ***********************创建的应用一定要去配置文件中注册**********************
    INSTALLED_APPS = [
        'django.contrib.admin',
        'django.contrib.auth',
        'django.contrib.contenttypes',
        'django.contrib.sessions',
        'django.contrib.messages',
        'django.contrib.staticfiles',
        'app01.apps.App01Config',  # 全写
      	'app01',			 # 简写
    ]
    # 创建出来的的应用第一步先去配置文件中注册
    ps:你在用pycharm创建项目的时候 pycharm可以帮你创建一个app并且自动注册
    ***********************************************************************
    

    主要文件介绍

    -mysite项目文件夹
    	--mysite文件夹
      	---settings.py	    配置文件
        ---urls.py			路由与视图函数对应关系(路由层)
        ---wsgi.py			wsgiref模块(不考虑)
      --manage.py			django的入口文件
      --db.sqlite3			django自带的sqlite3数据库(小型数据库 功能不是很多还有bug)
      --app01文件夹
      	---admin.py			django后台管理
        ---apps.py			注册使用
        ---migrations文件夹		数据库迁移记录
        ---models.py		数据库相关的 模型类(orm)
      	---tests.py			测试文件
        ---views.py			视图函数(视图层)
    

    主要内容

    DJango小白必会三板斧

    from django.shortcuts import HttpResponse,render,redirect
    
    return HttpResponse('字符串') # 返回字符串类型的数据
    
    return render(request,'login.html') # 返回html文件的
    def ab_render(request): 
        # 视图函数必须要接受一个形参request
        user_dict = {'username':'jason','age':18}
        # 第一种传值方式:更加的精确 节省资源
        # return render(request,'01 ab_render.html',{'data':user_dict,'date':123})
        # 第二种传值方式:当你要传的数据特别多的时候
        """locals会将所在的名称空间中所有的名字全部传递给html页面"""
        return render(request,'01 ab_render.html',locals())
    	
    return redirect(url) # 重定向
    

    静态文件配置

    # 登陆功能
    
    """
    我们将html文件默认都放在templates文件夹下
    我们将网站所使用的静态文件默认都放在static文件夹下
    
    静态文件
    	前端已经写好了的 能够直接调用使用的文件
    		网站写好的js文件
    		网站写好的css文件
    		网站用到的图片文件
    		第三方前端框架
    		...
    		拿来就可以直接使用的
    """
    # django默认是不会自动帮你创建static文件夹 需要你自己手动创建
    一般情况下我们在static文件夹内还会做进一步的划分处理
    	-static
      	--js
        --css
        --img
        其他第三方文件
    
    """
    在浏览器中输入url能够看到对应的资源
    是因为后端提前开设了该资源的借口
    如果访问不到资源 说明后端没有开设该资源的借口
    
    http://127.0.0.1:8000/static/bootstrap-3.3.7-dist/css/bootstrap.min.css
    """
    
    # 静态文件配置
    
    """
    ****************************************************************
    当你在写django项目的时候 可能会出现后端代码修改了但是前端页面没有变化的情况
    	1.你在同一个端口开了好几个django项目 
    		一直在跑的其实是第一个django项目
    	
    	2.浏览器缓存的问题
    		settings
    			network
    				disable cache 勾选上	
    *****************************************************************
    """
    
    STATIC_URL = '/ooo/'  # 类似于访问静态文件的令牌
    """如果你想要访问静态文件 你就必须以static开头"""
    """
    /static/bootstrap-3.3.7-dist/js/bootstrap.min.js
    
    /static/令牌
    取列表里面从上往下依次查找
        bootstrap-3.3.7-dist/js/bootstrap.min.js
        都没有才会报错
    """
    # 静态文件配置
    STATICFILES_DIRS = [
        os.path.join(BASE_DIR,'static'),
        os.path.join(BASE_DIR,'static1'),
        os.path.join(BASE_DIR,'static2'),
    ]
    
    # 静态文件动态解析
        {% 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>
        
        
    # form表单默认是get请求数据
    	http://127.0.0.1:8000/login/?username=jason&password=123
    """
    form表单action参数
    	1.不写 默认朝当前所在的url提交数据
    	2.全写 指名道姓
    	3.只写后缀 /login/
    """
    
    
    # 在前期我们使用django提交post请求的时候 需要取配置文件中注释掉一行代码
    MIDDLEWARE = [
        'django.middleware.security.SecurityMiddleware',
        'django.contrib.sessions.middleware.SessionMiddleware',
        'django.middleware.common.CommonMiddleware',
        # 'django.middleware.csrf.CsrfViewMiddleware',
        'django.contrib.auth.middleware.AuthenticationMiddleware',
        'django.contrib.messages.middleware.MessageMiddleware',
        'django.middleware.clickjacking.XFrameOptionsMiddleware',
    ]
    

    request对象方法初识

    request.method # 返回请求方式 并且是全大写的字符串形式  <class 'str'>
    request.POST  # 获取用户post请求提交的普通数据不包含文件
    	request.POST.get()  # 只获取列表最后一个元素
      request.POST.getlist()  # 直接将列表取出
    request.GET  # 获取用户提交的get请求数据
    	request.GET.get()  # 只获取列表最后一个元素
      request.GET.getlist()  # 直接将列表取出
    """
    get请求携带的数据是有大小限制的 大概好像只有4KB左右
    而post请求则没有限制
    """
      
    def login(request):
        # 返回一个登陆界面
        """
        get请求和post请求应该有不同的处理机制
        :param request: 请求相关的数据对象 里面有很多简易的方法
        :return:
        """
        # print(type(request.method))  # 返回请求方式 并且是全大写的字符串形式  <class 'str'>
        # if request.method == 'GET':
        #     print('来了 老弟')
        #     return render(request,'login.html')
        # elif request.method == 'POST':
        #     return HttpResponse("收到了 宝贝")
        
        if request.method == 'POST':
            return HttpResponse("收到了 宝贝")
        return render(request, 'login.html')
    

    pycharm链接数据库(MySQL)

    """
    三个位置查找数据库相关
    	右侧上方database
    	左下方database
    	配置里面的plugins插件搜索安装
    	
    	再没有卸载pycharm重新装	
    
    pycharm可以充当很多款数据库软件的客户端
    
    参考截图和视频操作即可
    	需要提前创建好库
    """
    

    django链接数据库(MySQL)

    # 默认用的是sqkite3
    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.sqlite3',
            'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
        }
    }
    
    # django链接MySQL
    	1.第一步配置文件中配置
      	DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'NAME': 'day60',
            'USER':'root',
            'PASSWORD':'admin123',
            'HOST':'127.0.0.1',
            'PORT':3306,
            'CHARSET':'utf8'
        }
    }
      2.代码声明	
      	django默认用的是mysqldb模块链接MySQL
        但是该模块的兼容性不好 需要手动改为用pymysql链接
        
        你需要告诉django不要用默认的mysqldb还是用pymysql
        # 在项目名下的init或者任意的应用名下的init文件中书写以下代码都可以
        import pymysql
    		pymysql.install_as_MySQLdb()
    

    Django ORM

    """
    ORM. 对象关系映射
    作用:能够让一个不用sql语句的小白也能够通过python 面向对象的代码简单快捷的操作数据库
    不足之处:封装程度太高 有时候sql语句的效率偏低 需要你自己写SQL语句
    
    类											表
    
    对象									记录
    	
    对象属性							记录某个字段对应的值
    
    
    应用下面的models.py文件
    """
    
    # 1 先去models.py中书写一个类
    	class User(models.Model):
        # id int primary_key auto_increment
        id = models.AutoField(primary_key=True)
        # username varchar(32)
        username = models.CharField(max_length=32)
        # password int
        password = models.IntegerField()
    
    *************************# 2 数据库迁移命令*************************
    python3 manage.py makemigrations 将操作记录记录到小本本上(migrations文件夹)
    
    python3 manage.py migrate  将操作真正的同步到数据库中
    # 只要你修改了models.py中跟数据库相关的代码 就必须重新执行上述的两条命令
    ******************************************************************
    
    class User(models.Model):
        # id int primary_key auto_increment
        id = models.AutoField(primary_key=True,verbose_name='主键')
        # username varchar(32)
        username = models.CharField(max_length=32,verbose_name='用户名')
        """
        CharField必须要指定max_length参数 不指定会直接报错
        verbose_name该参数是所有字段都有的 就是用来对字段的解释
        """
        # password int
        password = models.IntegerField(verbose_name='密码')
    
    
    class Author(models.Model):
        # 由于一张表中必须要有一个主键字段 并且一般情况下都叫id字段
        # 所以orm当你不定义主键字段的时候 orm会自动帮你创建一个名为id主键字段
        # 也就意味着 后续我们在创建模型表的时候如果主键字段名没有额外的叫法 那么主键字段可以省略不写
        # username varchar(32)
        username = models.CharField(max_length=32)
        # password int
        password = models.IntegerField()
    

    字段的增删改查

    # 字段的增加
    	1.可以在终端内直接给出默认值
      2.该字段可以为空
        info = models.CharField(max_length=32,verbose_name='个人简介',null=True)
      3.直接给字段设置默认值
        hobby = models.CharField(max_length=32,verbose_name='兴趣爱好',default='study')
     
    # 字段的修改
    	直接修改代码然后执行数据库迁移的两条命令即可!
    
    # 字段的删
    	直接注释对应的字段然后执行数据库迁移的两条命令即可!
      执行完毕之后字段对应的数据也都没有了
      
    """
    在操作models.py的时候一定要细心
    	千万不要注释一些字段
    	执行迁移命令之前最好先检查一下自己写的代码
    """
    
    # 个人建议:当你离开你的计算机之后一定要锁屏
    

    数据的增删改查

    # 今天只会介绍一点点 后面会详细的介绍
    
    # 查
    res = models.User.objects.filter(username=username)
    """
    返回值你先看成是列表套数据对象的格式
    它也支持索引取值 切片操作 但是不支持负数索引
    它也不推荐你使用索引的方式取值
    user_obj = models.User.objects.filter(username=username).first()
    """
    filter括号内可以携带多个参数 参数与参数之间默认是and关系
    你可以把filter联想成where记忆
    
    
    
    # 增
    from app01 import models
    res = models.User.objects.create(username=username,password=password)
    # 返回值就是当前被创建的对象本身
    
    # 第二种增加
    user_obj = models.User(username=username,password=password)
    user_obj.save()  # 保存数据
    
    # 先讲数据库中的数据全部展示到前端 然后给每一个数据两个按钮 一个编辑一个删除
    
    # 查看
    def userlist(request):
        # 查询出用户表里面所有的数据
        # 方式1
        # data = models.User.objects.filter()
        # print(data)
        # 方式2
        user_queryset = models.User.objects.all()
        # return render(request,'userlist.html',{'user_queryset':user_queryset})
        return render(request,'userlist.html',locals())
    
    # 编辑功能
    	# 点击编辑按钮朝后端发送编辑数据的请求
      """
      如何告诉后端用户想要编辑哪条数据?
      	将编辑按钮所在的那一行数据的主键值发送给后端
      	利用url问号后面携带参数的方式
      	
      	{% for user_obj in user_queryset %}
                            <tr>
                                <td>{{ user_obj.id }}</td>
                                <td>{{ user_obj.username }}</td>
                                <td>{{ user_obj.password }}</td>
                                <td>
                                    <a href="/edit_user/?user_id={{ user_obj.id }}" class="btn btn-primary btn-xs">编辑</a>
                                    <a href="" class="btn btn-danger btn-xs">删除</a>
                                </td>
                            </tr>
                        {% endfor %}
      """
      # 后端查询出用户想要编辑的数据对象 展示到前端页面供用户查看和编辑
      def edit_user(request):
        # 获取url问号后面的参数
        edit_id = request.GET.get('user_id')
        # 查询当前用户想要编辑的数据对象
        edit_obj = models.User.objects.filter(id=edit_id).first()
    
        if request.method == "POST":
            username = request.POST.get('username')
            password = request.POST.get('password')
            # 去数据库中修改对应的数据内容
            # 修改数据方式1
            # models.User.objects.filter(id=edit_id).update(username=username,password=password)
            """
                将filter查询出来的列表中所有的对象全部更新            批量更新操作
                只修改被修改的字段
            """
    
            # 修改数据方式2
            edit_obj.username = username
            edit_obj.password= password
            edit_obj.save()
            """
                上述方法当字段特别多的时候效率会非常的低
                从头到尾将数据的所有字段全部更新一边 无论该字段是否被修改
            """
            
            # 跳转到数据的展示页面
            return redirect('/userlist/')
    
    
    
        # 将数据对象展示到页面上
        return render(request,'edit_user.html',locals())
    
    # 删除功能
    	"""
    	跟编辑功能逻辑类似
    	def delete_user(request):
        # 获取用户想要删除的数据id值
        delete_id = request.GET.get('user_id')
        # 直接去数据库中找到对应的数据删除即可
        models.User.objects.filter(id=delete_id).delete()
        """
            批量删除
        """
        # 跳转到展示页面
    
        return redirect('/userlist/')	
    	
    	"""
    # 真正的删除功能应该需要二次确认 我们这里先不做后面会讲
    # 删除数据内部其实并不是真正的删除 我们会给数据添加一个标识字段用来表示当前数据是否被删除了,如果数据被删了仅仅只是讲字段修改一个状态
    	username password	is_delete
      jason			123				0
      egon			123				1
    

    django orm中如何创建表关系

    """
    表与表之间的关系
    	一对多
    	
    	多对多
    	
    	一对一
    	
    	没有关系
    
    判断表关系的方法:换位思考
    """
    图书表
    
    出版社表
    
    作者表
    
    作者详情表
    
    
    """
    图书和出版社是一对多的关系 外键字段建在多的那一方 book
    	
    图书和作者是多对多的关系 需要创建第三张表来专门存储
    
    作者与作者详情表是一对一
    """
    from django.db import models
    
    # Create your models here.
    
    
    # 创建表关系  先将基表创建出来 然后再添加外键字段
    class Book(models.Model):
        title = models.CharField(max_length=32)
        price = models.DecimalField(max_digits=8,decimal_places=2)
        # 总共八位 小数点后面占两位
        """
        图书和出版社是一对多 并且书是多的一方 所以外键字段放在书表里面
        """
        publish = models.ForeignKey(to='Publish')  # 默认就是与出版社表的主键字段做外键关联
        """
        如果字段对应的是ForeignKey 那么会orm会自动在字段的后面加_id
        如果你自作聪明的加了_id那么orm还是会在后面继续加_id
        
        后面在定义ForeignKey的时候就不要自己加_id
        """
    
    
        """
        图书和作者是多对多的关系 外键字段建在任意一方均可 但是推荐你建在查询频率较高的一方
        """
        authors = models.ManyToManyField(to='Author')
        """
        authors是一个虚拟字段 主要是用来告诉orm 书籍表和作者表是多对多关系
        让orm自动帮你创建第三张关系表
        """
    
    
    class Publish(models.Model):
        name = models.CharField(max_length=32)
        addr = models.CharField(max_length=32)
    
    
    class Author(models.Model):
        name = models.CharField(max_length=32)
        age = models.IntegerField()
        """
        作者与作者详情是一对一的关系 外键字段建在任意一方都可以 但是推荐你建在查询频率较高的表中
        """
        author_detail = models.OneToOneField(to='AuthorDetail')
        """
        OneToOneField也会自动给字段加_id后缀
        所以你也不要自作聪明的自己加_id
        """
    
    class AuthorDetail(models.Model):
        phone = models.BigIntegerField()  # 或者直接字符类型
        addr = models.CharField(max_length=32)
    
    
    """
    	orm中如何定义三种关系
    		publish = models.ForeignKey(to='Publish')  # 默认就是与出版社表的主键字段做外键关联
    		
    		authors = models.ManyToManyField(to='Author')
    		
    		author_detail = models.OneToOneField(to='AuthorDetail')
    		
    		
    		ForeignKey
    		OneToOneField
    			会自动在字段后面加_id后缀
    """
    
    # 在django1.X版本中外键默认都是级联更新删除的
    # 多对多的表关系可以有好几种创建方式 这里暂且先介绍一种
    # 针对外键字段里面的其他参数 暂时不要考虑 如果感兴趣自己可以百度试试看
    

    django请求生命周期流程图(必会)

    # 每个人都要会画 这个图是你们后期复习django最好的一个梳理方式
    
    
    # 扩展知识点
    	"""
    	缓存数据库
    		提前已经将你想要的数据准备好了 你来直接拿就可以
    		提高效率和响应时间
    		
    	当你在修改你的数据的时候 你会发现数据并不是立刻修改完成的
    	而是需要经过一段时间才会修改
    		博客园
    	
    	了解即可
    	"""
    

  • 相关阅读:
    bzoj1015星球大战(并查集+离线)
    bzoj1085骑士精神(搜索)
    bzoj1051受欢迎的牛(Tarjan)
    左偏树学习
    hdu1512 Monkey King(并查集,左偏堆)
    左偏树(模板)
    PAT (Basic Level) Practice (中文) 1079 延迟的回文数 (20分) (大数加法)
    PAT (Basic Level) Practice (中文) 1078 字符串压缩与解压 (20分) (字符转数字——栈存放)
    PAT (Basic Level) Practice (中文) 1077 互评成绩计算 (20分) (四舍五入保留整数)
    PAT (Basic Level) Practice (中文) 1076 Wifi密码 (15分)
  • 原文地址:https://www.cnblogs.com/Lance-WJ/p/12961157.html
Copyright © 2011-2022 走看看