zoukankan      html  css  js  c++  java
  • Django基础-001

    一、开发模式

    MVC模式:
    model:数据库
    view:前端展示
    controller:逻辑控制
    MTV模式
    model:数据库
    view:逻辑控制
    template:前端展示

    二、Django介绍

    flask,FastApi是轻量级服务端开发框架

    Django是重量级服务端开发框架

    ORM:封装了数据库操作

    form:校验请求数据

    安装Django:

    pip install django==2.1   #指定版本安装,默认是安装最新版本

    注意:最新版本的Django对mysql版本也有要求

    三、Django命令

    1.创建项目命令:django-admin startproject ssz_django

    2.启动项目命令:

      python manage.py runserver  默认端口启动8000

      python manage.py runserver  0.0.0.0:8002   指定端口启动,别人也可以访问

      python manage.py runserver  127.0.0.1:8002 指定端口启动,只能自己访问

    3.创建子模块:python manage.py startapp user

    4.创建表结构:

      python manage.py makemigrations  #生成建表/更新表的py文件

      python manage.py migrate  #根据上面命令生成的py文件,来建表/更新表

    5.查询命令

      python manage.py --help

    四、pycharm操作

    4.1 pycharm创建项目

    File--New Project--Django

    4.2 pycharm创建子模块

    Tools--Run manage.py Task 进入命令行

    startapp user  #创建user子模块

    五、Django项目介绍

    5.1 项目整体结构

    5.2 urls.py

    该文件是用来配置url的

     1 from django.contrib import admin
     2 from django.urls import path
     3 from user import views #引入模块
     4 
     5 urlpatterns = [
     6     path('admin/', admin.site.urls),
     7     path('index/', views.user_info),
     8     path('welcome/',views.welcome),
     9     path('',views.index),#配置url
    10 ]

    5.3 settings.py

    该文件是配置文件,数据库等配置

      1 import os
      2 
      3 # Build paths inside the project like this: os.path.join(BASE_DIR, ...)
      4 BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
      5 
      6 
      7 # Quick-start development settings - unsuitable for production
      8 # See https://docs.djangoproject.com/en/2.1/howto/deployment/checklist/
      9 
     10 # SECURITY WARNING: keep the secret key used in production secret!
     11 SECRET_KEY = '6ui+975ck&h4o8f9ga!lnz%j7u&se&-%69&-(h(4!-q4n80y9c'
     12 
     13 # SECURITY WARNING: don't run with debug turned on in production!
     14 DEBUG = True
     15 
     16 ALLOWED_HOSTS = []
     17 
     18 
     19 # Application definition
     20 
     21 INSTALLED_APPS = [ #加增加的应用
     22     'django.contrib.admin',
     23     'django.contrib.auth',
     24     'django.contrib.contenttypes',
     25     'django.contrib.sessions',
     26     'django.contrib.messages',
     27     'django.contrib.staticfiles',
     28     'user',
     29     'test_tools',
     30     'case'
     31 ]
     32 
     33 MIDDLEWARE = [
     34     'django.middleware.security.SecurityMiddleware',
     35     'django.contrib.sessions.middleware.SessionMiddleware',
     36     'django.middleware.common.CommonMiddleware',
     37     'django.middleware.csrf.CsrfViewMiddleware',
     38     'django.contrib.auth.middleware.AuthenticationMiddleware',
     39     'django.contrib.messages.middleware.MessageMiddleware',
     40     'django.middleware.clickjacking.XFrameOptionsMiddleware',
     41 ]
     42 
     43 ROOT_URLCONF = 'sky.urls'
     44 
     45 TEMPLATES = [
     46     {
     47         'BACKEND': 'django.template.backends.django.DjangoTemplates',
     48         'DIRS': [os.path.join(BASE_DIR,'templates')],#指的是Django寻找html的目录
     49         'APP_DIRS': True,
     50         'OPTIONS': {
     51             'context_processors': [
     52                 'django.template.context_processors.debug',
     53                 'django.template.context_processors.request',
     54                 'django.contrib.auth.context_processors.auth',
     55                 'django.contrib.messages.context_processors.messages',
     56             ],
     57         },
     58     },
     59 ]
     60 
     61 WSGI_APPLICATION = 'sky.wsgi.application'
     62 
     63 
     64 # Database
     65 # https://docs.djangoproject.com/en/2.1/ref/settings/#databases
     66 
     67 DATABASES = {
     68     'default': {
     69         'ENGINE': 'django.db.backends.sqlite3',
     70         'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
     71     }
     72 }
     73 
     74 
     75 # Password validation
     76 # https://docs.djangoproject.com/en/2.1/ref/settings/#auth-password-validators
     77 
     78 AUTH_PASSWORD_VALIDATORS = [
     79     {
     80         'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
     81     },
     82     {
     83         'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
     84     },
     85     {
     86         'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
     87     },
     88     {
     89         'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
     90     },
     91 ]
     92 
     93 
     94 # Internationalization
     95 # https://docs.djangoproject.com/en/2.1/topics/i18n/
     96 
     97 #LANGUAGE_CODE = 'en-us' #英文
     98 LANGUAGE_CODE = 'zh-Hans'#中文
     99 
    100 TIME_ZONE = 'Asia/Shanghai'#时区
    101 
    102 USE_I18N = True
    103 
    104 USE_L10N = True
    105 
    106 USE_TZ = False#True:往数据库里插数据,用的标准时区的时间
    107 
    108 
    109 # Static files (CSS, JavaScript, Images)
    110 # https://docs.djangoproject.com/en/2.1/howto/static-files/
    111 
    112 STATIC_URL = '/static/'
    113 
    114 STATICFILES_DIRS = (
    115     os.path.join(BASE_DIR,'static'),
    116 )
    117 
    118 MEDIA_ROOT = os.path.join(BASE_DIR,'images')#图片的总目录
    119 MEDIA_URL = '/images/'

    5.4 wsgj.py

    该文件是用来部署用的

    5.5 manage.py

    项目管理文件

    5.6 models.py

    操作数据库文件

    建单表代码

     1 from django.db import models
     2 
     3 # Create your models here.
     4 class Category(models.Model):
     5     name = models.CharField(verbose_name='分类名称',max_length=20,unique=True)
     6     create_time = models.DateTimeField(verbose_name='创建时间',auto_now_add=True)
     7     update_time = models.DateTimeField(verbose_name='修改时间',auto_now=True)
     8     class Meta:
     9         db_table = 'category' #指定表名
    10         verbose_name = '分类'
    11         verbose_name_plural = verbose_name
    12         ordering = ['-create_time','name'] #排序,默认是升序,-是降序

    建有外键的表的代码

     1 class Article(models.Model):
     2     title = models.CharField(verbose_name='标题',max_length=50)
     3     content = models.TextField(verbose_name='文章内容')
     4     category = models.ForeignKey(Category,on_delete=models.DO_NOTHING,db_constraint=False,verbose_name='分类')
     5     #建外键,on_delete=models.DO_NOTHING:当分类被删除时,文章不被影响
     6     #db_constraint = False:不会在表中建立真实的外键关系
     7 
     8     img = models.ImageField(upload_to='article',verbose_name='文章图片',blank=True)#图片存放的文件夹
     9     create_time = models.DateTimeField(verbose_name='创建时间', auto_now_add=True)
    10     update_time = models.DateTimeField(verbose_name='修改时间', auto_now=True)
    11     class Meta:
    12         db_table = 'article' #指定表名
    13         verbose_name = '文章'
    14         verbose_name_plural = verbose_name
    15         ordering = ['-create_time'] #排序,默认是升序,-是降序

    代码写好后,分别执行以下命令,就可以生成表结构

     python manage.py makemigrations

     python manage.py migrate

    Django 内嵌了sqllite,默认就是将表创建在sqllite中

    如果想要连接mysql等其他数据库,需要自己在settings.py文件中配置

    关联删除模式:

    #外键删除操作模式
        #models.DO_NOTHING:不受任何影响
        #models.CASCADE:关联的数据也会被删除,分类被删除,引用分类的文章也会被删除
        #models.SET:传入一个方法名,用方法逻辑处理
        #models.SET_DEFAULT:删除了,设置为默认值,要该字段有默认值
        #models.SET_NULL:删除了,直接设置为空,要该字段可为空
        #models.PROTECT#受保护,不能删除,只要这个分类下有文章,就不能删除这个分类

    5.7 views.py

    是用来做逻辑处理的文件

     1 from django.http import HttpResponse
     2 from django.shortcuts import render
     3 from . import models
     4 
     5 # Create your views here.
     6 
     7 def user_info(request):
     8     s = '你好'
     9     return HttpResponse(s)#返回的是字符串
    10 
    11 
    12 def welcome(request):
    13     username = '谢谢啦dddd'
    14     # f = open('G:\pythonWorkspace\day018\sky\templates\welcome.html',encoding='utf-8')
    15     # content = f.read()
    16     # new_content = content.replace('{{ uname }}',username)
    17     # return HttpResponse(new_content)
    18     # render 就等于上面的一系列操作
    19     return render(request,'welcome.html',{'uname':username})
    20 
    21 
    22 def index(request):
    23     categories = models.Category.objects.all()
    24     articles = models.Article.objects.all()
    25     return render(request,'index.html',{'categories':categories,'articles':articles})

    5.8 ORM操作数据库

    5.8.1 增加

    1 #第一种方式:增加
    2 category = models.Category(name='mysql')
    3 category.save()
    4 
    5 #第二种方式:增加
    6 models.Category.objects.create(name='心情日记')

    5.8.2 修改

    1 #修改
    2 c1 = models.Category.objects.get(id=1)
    3 c1.name = 'Java'
    4 c1.save()#单个数据修改
    5 
    6 #多个数据修改
    7 q = models.Category.objects.filter(name='python')
    8 q.update(name='Python1')

    5.8.3 查询

     1 #查询
     2 #只能返回一条数据,如果返回多条数据会报错
     3 #如果指定的条件查询不到数据,也会报错
     4 c1 = models.Category.objects.get(name='linux',id=2)
     5 
     6 #可以返回多条数据,返回结果为list,如果查询不到结果,则返回空
     7 query_set = models.Category.objects.filter(name='python',id=8)
     8 print(query_set.first().name)
     9 print(query_set[1])
    10 print(query_set)
    11 
    12 #查询所有的数据
    13 categories = models.Category.objects.all()

    5.8.4 删除

    1 #删除
    2 #单条数据删除
    3 c1 = models.Category.objects.get(id=1)
    4 c1.delete()
    5 
    6 #多条数据删除
    7 q = models.Category.objects.filter(name='Python1')
    8 q.delete()

    5.9 test.py

    测试代码

    注意:需要手动加入Django配置,才可以测试

    运行Django项目时,不需要手动设置,因为在manager.py文件中配置了

    1 import os,django
    2 os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'sky.settings')#设置数据库的路径
    3 django.setup()
     1 from django.test import TestCase
     2 import os,django
     3 os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'sky.settings')#设置数据库的路径
     4 django.setup()
     5 
     6 # Create your tests here.
     7 from user import models
     8 
     9 #增加
    10 category = models.Category(name='mysql')
    11 category.save()
    12 
    13 models.Category.objects.create(name='心情日记')
    14 #删除
    15 #单条数据删除
    16 # c1 = models.Category.objects.get(id=1)
    17 # c1.delete()
    18 
    19 #多条数据删除
    20 # q = models.Category.objects.filter(name='Python1')
    21 # q.delete()
    22 
    23 #修改
    24 # c1 = models.Category.objects.get(id=1)
    25 # c1.name = 'Java'
    26 # c1.save()#单个数据修改
    27 
    28 #多个数据修改
    29 # q = models.Category.objects.filter(name='python')
    30 # q.update(name='Python1')
    31 
    32 
    33 #查询
    34 #只能返回一条数据,如果返回多条数据会报错
    35 #如果指定的条件查询不到数据,也会报错
    36 c1 = models.Category.objects.get(name='linux',id=2)
    37 
    38 #可以返回多条数据,返回结果为list,如果查询不到结果,则返回空
    39 query_set = models.Category.objects.filter(name='python',id=8)
    40 print(query_set.first().name)
    41 print(query_set[1])
    42 print(query_set)
    43 
    44 #查询所有的数据
    45 categories = models.Category.objects.all()
    46 
    47 # c = models.Category.objects.get(id=2)
    48 # models.Article.objects.create(title='test00001',content='fsdfslkjfslkjflsdkjflsdjflsdjflskjfdslfjsd',category=c)
    49 # models.Article.objects.create(title='Django项目配置',content='Django项目配置Django项目配置Django项目配置Django项目配置Django项目配置',category_id=3)
    50 
    51 models.Article.objects.create(title='python面向对象1',content='python面向对象1python面向对象1python面向对象1',category_id=3)
    52 models.Article.objects.create(title='python面向对象2',content='python面向对象2python面向对象2python面向对象2',category_id=3)
    53 article = models.Article.objects.get(id='1')
    54 print(article.title)
    55 print(article.category.name)
  • 相关阅读:
    Kotlin 学习 (一)
    Spring Boot 学习(一)
    三大特性之继承
    OC中的点语法
    getter和setter
    三大特性之封装
    匿名对象
    对象作为返回值
    对象作为参数的连续传递
    对象作为参数传递
  • 原文地址:https://www.cnblogs.com/cjxxl1213/p/13510309.html
Copyright © 2011-2022 走看看