1. 程式人生 > 實用技巧 >Django基礎-01篇

Django基礎-01篇

一、Django介紹

flask,FastApi是輕量級服務端開發框架

Django是重量級服務端開發框架

ORM:封裝了資料庫操作

form:校驗請求資料

安裝Django:

pip install django==2.1.7 #指定版本安裝,預設是安裝最新版本

注意:最新版本的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檔案,來建表/更新表

三、Django專案介紹

3.1 專案整體結構

3.2 urls.py

該檔案是用來配置url的

from django.contrib import admin
from django.urls import
path from user import views urlpatterns = [ path('admin/', admin.site.urls), path('index/', views.index), path('get_sign', views.get_sign), path('category_view', views.category_view), path('category/<int:id>', views.category), path('article/<int:id>', views.detail), ]

3.3 settings.py

該檔案是配置檔案,資料庫等配置

import os

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))


# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/2.1/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = '^28j+9pchzsrhs0w1p5n9hz+bp&4)dek8n8zd1+y0e+g4vvpxb'

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True

ALLOWED_HOSTS = ['*']  #設定允許那些ip可以進行訪問,如果允許所有,則寫成['*']


# Application definition

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'user',
    'order'
]

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',
]  # 中介軟體用到

ROOT_URLCONF = 'sky.urls'

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR, 'templates')],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
            ],
        },
    },
]  # 前後端不分離時用到

WSGI_APPLICATION = 'sky.wsgi.application'


# Database
# https://docs.djangoproject.com/en/2.1/ref/settings/#databases

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}  # 資料庫配置


# Password validation
# https://docs.djangoproject.com/en/2.1/ref/settings/#auth-password-validators

AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    },
]


# Internationalization
# https://docs.djangoproject.com/en/2.1/topics/i18n/

LANGUAGE_CODE = 'zh-Hans'  # 設定語言,'en-us':英文,'zh-Hans':中文

TIME_ZONE = 'Asia/Shanghai'  # 設定時區,'UTC':標準時區,'Asia/Shanghai':亞洲上海時區

USE_I18N = True

USE_L10N = True

USE_TZ = False  # 設定是否使用標準時區時間,我們設定為False


# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/2.1/howto/static-files/

STATIC_URL = '/static/'
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]  # 設定靜態檔案目錄

  

3.4 wsgj.py

該檔案是用來部署用的

3.5manage.py

專案管理檔案

3.6models.py

操作資料庫檔案

from django.db import models

# Create your models here.
# 建立表結構的地方

class BasicModel(models.Model):
    create_time = models.DateTimeField(verbose_name='建立時間', auto_now_add=True)
    update_time = models.DateTimeField(verbose_name='修改時間', auto_now=True)

    class Meta:
        abstract = True


class Category(BasicModel):
    name = models.CharField(verbose_name='分類名稱',max_length=50,unique=True)


    class Meta:
        db_table = 'category'
        verbose_name = '文章分類'  # 在admin後臺顯示錶名
        verbose_name_plural = verbose_name  # 在admin後臺顯示錶名的複數形式

        ordering = ['id']  # 根據某些欄位進行升序排序
        # ordering = ['-id']  # 有- 根據某些欄位進行降序排序

    # 定義下面的函式實現在admin後臺中展示欄位,從而代替展示的 tablename objects
    def __str__(self):
        return self.name

class Article(BasicModel):
    title = models.CharField(verbose_name='文章標題', max_length=50)
    content = models.TextField(verbose_name='文章內容')  # 長文字
    read_count = models.IntegerField(verbose_name='閱讀次數', default=0)
    category = models.ForeignKey(Category, on_delete=models.PROTECT, verbose_name='分類')

    class Meta:
        db_table = 'article'
        verbose_name = '文章'
        verbose_name_plural = verbose_name

    def __str__(self):
        return self.title

程式碼寫好後,分別執行以下命令,就可以生成表結構

 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#受保護,不能刪除,只要這個分類下有文章,就不能刪除這個分類

3.7views.py

是用來做邏輯處理的檔案

from django.shortcuts import render
from django.shortcuts import HttpResponse
from . import models

# Create your views here.
# 寫邏輯的地方

def index(request):
    # return HttpResponse('hello django!')
    categories = models.Category.objects.all()
    articles = models.Article.objects.all()
    title = 'my blog'
    return render(request, 'index.html', {'title': title, 'categories': categories, 'articles': articles})  # 第三個引數,把值傳到html頁面上

def get_sign(request):
    print(request.method)  # 請求方式
    print(request.body)  # 請求體
    print(request.META)  # 請求頭
    print(request.GET)  # url裡面的引數都在GET   url? a=1&b=2
    print(request.POST)  # POST中的引數  k-v,k1=v1
    print(request.FILES)  # 檔案
    print(request.COOKIES)  # cookies
    return HttpResponse('sign')

def category_view(request):
    c = models.Category.objects.all() # 查詢所有的資料
    for i in c:
        print(i.name)
        print(i.create_time)
        print(i.update_time)
    print('=====================')
    s = models.Category.objects.get(id=3)  # 使用get,必須要保證返回的只有1條結果
    print(s.name)
    f = models.Category.objects.filter(name='java', id=3)  # 進行過濾,返回多條結果

    result = models.Category.objects.filter(name='mysql').exists()  # 使用過濾後,利用exists方法判斷是否存在
    print(result)
    result = models.Category.objects.filter(name='java').count()  # 使用過濾後,利用count方法統計返回條數
    print(result)
    return HttpResponse('ok')

def category(request, id):
    categories = models.Category.objects.all()
    articles = models.Article.objects.filter(category_id=id)
    # print(articles.first())  # 返回第一個
    # print(articles.last())  # 返回最後一個
    return render(request, 'category.html', {'articles': articles, 'categories': categories})

def detail(request,id):
    article = models.Article.objects.get(id=id)
    counts = article.read_count
    counts += 1

    return render(request, 'detail.html', {'article': article, 'counts': counts})

3.8ORM操作資料庫

def category_view(request):
    c = models.Category.objects.all() # 查詢所有的資料
    for i in c:
        print(i.name)
        print(i.create_time)
        print(i.update_time)
    print('=====================')
    s = models.Category.objects.get(id=3)  # 使用get,必須要保證返回的只有1條結果
    print(s.name)
    f = models.Category.objects.filter(name='java', id=3)  # 進行過濾,返回多條結果

    result = models.Category.objects.filter(name='mysql').exists()  # 使用過濾後,利用exists方法判斷是否存在
    print(result)
    result = models.Category.objects.filter(name='java').count()  # 使用過濾後,利用count方法統計返回條數
    print(result)
    return HttpResponse('ok')

5.9test.py

測試程式碼

注意:需要手動加入Django配置,才可以測試