django 基礎

来源:https://www.cnblogs.com/JcrLive/archive/2020/03/02/12398275.html
-Advertisement-
Play Games

基本配置 一、創建django程式 終端命令: django-admin startproject sitename IDE創建django程式時,本質上都是自動執行上述命令 其他常用命令:進入工程目錄 python manage.py runserver 127.0.0.1 埠號 運行測試 py ...


 

基本配置

一、創建django程式

  • 終端命令:
  • django-admin startproject sitename        IDE創建django程式時,本質上都是自動執行上述命令

    其他常用命令:進入工程目錄

      python manage.py runserver 127.0.0.1 埠號       運行測試
      python manage.py startapp appname  添加app
      python manage.py makemigrations     
      python manage.py migrate      上兩個命令一起使用,載入資料庫     

  •   python manage.py createsuperuser   創建superuser

二、程式目錄   添加app後的目錄(請忽略名字......)

 

三、配置文件   settings.py

1、資料庫

DATABASES = {
    'default': {
    'ENGINE': 'django.db.backends.mysql',
    'NAME':'dbname',
    'USER': 'xxx',
    'PASSWORD': 'xxx',
    'HOST': '',
    'PORT': '',
    }
}


# 由於Django內部連接MySQL時使用的是MySQLdb模塊,但python3中沒有此模塊,所以需要使用pymysql來代替
  
# 在上圖與項目名相同的文件中的__init__.py 文件中添加
  
import pymysql
pymysql.install_as_MySQLdb() 
配置資料庫

2、靜態文件

1 STATICFILES_DIRS = (
2         os.path.join(BASE_DIR,'static'),
3     )

路由系統

 1、單一路由

1 urlpatterns = [
2     path('xxx/', views.xxx),
3 ]

2、正則路由

1 re_path('^(\w+)/(\w+)/download/(\d+)$', views.download,),
2 re_path('^(\w+)/(\w+)/downloads/(\d+)/(?<id>\d+)$', views.downloads,) ,

3 #為防止衝突,儘量加上^和$

3、額外的參數

1 re_path('^(\w+)/(\w+)/downloads/(\d+)/(?<id>\d+)$', views.downloads,{‘id’:11}),
2 # 用的不多 

4、為路由映射設置名稱  

1 path('xxx/', views.xxx, name='xxx'),
2 # 同正則

設置名稱之後,可以在不同的地方調用,如:

  • 模板中使用生成URL     {% url 'xxx' 參數 %}
  • 函數中使用生成URL     reverse('xxx', args=(參數,))      from django.urls import reverse
  • Model中使用獲取URL  自定義get_absolute_url() 方法
  •  1 class NewType(models.Model):
     2     caption = models.CharField(max_length=16)
     3 
     4 
     5     def get_absolute_url(self):
     6         """
     7         為每個對象生成一個URL
     8         應用:在對象列表中生成查看詳細的URL,使用此方法即可!!!
     9         :return:
    10         """
    11         # return '/%s/%s' % (self._meta.db_table, self.id)
    12         #
    13         from django.urls import reverse
    14         return reverse('NewType.Detail', kwargs={'nid': self.id})

    # 獲取請求匹配成功的url:request.resolver_match

     

5、路由分發   

 path('^xx/',include('xx.urls')),   # from django.urls import include

 

路由系統

1、模版執行

#一般用的是這三個
from django.shortcuts import render, HttpResponse, redirect


def xxx(request):
    ...
    return render(request, '模板路徑', [傳到前端的參數{key:value,...}])
    # return redirect('路徑')    # 重定向
    # return HttpResponse('傳到前端的內容')

# 其本質都是HttpResponse    看源碼

2、模版語言

    • {{ item }}
    • {% for item in item_list %}  {{ item }}  {% endfor %}
        forloop.counter
        forloop.first
        forloop.last 
    • {% if ordered_warranty %}  {% else %} {% endif %}
    • 母板:{% block title %}...{% endblock %}
      子板:{% extends "base.html" %}
         {% block title %}...{% endblock %}

3、simple_tag

# 在app中創建templatetags模塊
# 創建文件 xx.py




#!/usr/bin/env python
#coding:utf-8
from django import template
from django.utils.safestring import mark_safe
   
register = template.Library()
   
@register.simple_tag
def my_simple_time(參數):
    return  ...
   
@register.simple_tag
def my_input(id,arg):
    result = "<a href='#'></a>" 
    return mark_safe(result)

# return內容即渲染內容




# 在使用simple_tag的html文件中導入之前創建的 xx.py 文件名
{% load xx %}


#使用simple_tag
{% my_simple_time [參數]%}
{% my_input %}
可直接傳入render() 傳來的參數
流程

流程走完無法使用???

django 還不知道去哪裡載入simple_tag

so 需要告訴它怎麼找

在settings中配置app

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'xxxapp.apps.xxxappConfig',
    'xxxapp.templatetags',
]




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',
            ],
            'libraries': {
                'my_tags': 'xxx.templatetags.my_tags',
                'src_tags': 'xxxapp.templatetags.src_tags',
                'stu_tags': 'xxxx.templatetags.stu_tags',
            }
        },
    },
]



更多:https://docs.djangoproject.com/en/1.10/ref/templates/language/

中間件

 

django 中的中間件(middleware),在django中,中間件其實就是一個類,在請求到來和結束後,django會根據自己的規則在合適的時機執行中間件中相應的方法。

在django項目的settings模塊中,有一個 MIDDLEWARE_CLASSES 變數,其中每一個元素就是一個中間件。

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',
    'xxx.middleware.xx.Authentication'
]
# 在根項目文件夾中xxx/middleware的xx.py文件中Authentication類

process_request(self,request)
process_view(self, request, callback, callback_args, callback_kwargs)
process_template_response(self,request,response)
process_exception(self, request, exception)
process_response(self, request, response)

以上方法的返回值可以是None和HttpResonse對象,如果是None,則繼續按照django定義的規則向下執行,如果是HttpResonse對象,則直接將該對象返回給用戶。

 

 

自定義中間件

class xxxx(object):
      
    def process_request(self,request):
        pass
    def process_view(self, request, callback, callback_args, callback_kwargs):
        i =1
        pass
    def process_exception(self, request, exception):
        pass
      
    def process_response(self, request, response):
        return response


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',
    'xxx.middleware.xx.xxxx'
]

admin

由django提供的後臺管理系統

# 創建superuser
python manage.py createsuperuser   #文章開頭


# models.py 中添加表       文章開頭命令載入資料庫

class Customer(models.Model):
    name = models.CharField(max_length=32, blank=True, null=True)
    qq = models.CharField(max_length=64, unique=True)
    phone = models.CharField(max_length=64, blank=True, null=True)
    email = models.EmailField(verbose_name='常用郵箱', blank=True, null=True)
    status_choices = ((0, '已購買'),
                      (1, '未購買'))
    status = models.SmallIntegerField(choices=status_choices, default=0)
    product = models.ForeignKey('Product', on_delete=models.CASCADE)
    consultant = models.ForeignKey('UserProfile', on_delete=models.CASCADE)
    tag = models.ManyToManyField('Tag')
    date = models.DateTimeField(auto_now_add=True)  # 自動添加

    def __str__(self):
        return '{},{}'.format(self.qq, self.name)

    class Meta:
        verbose_name = '客戶'
        verbose_name_plural = '客戶'

在admin.py 中配置
from django.contrib import admin

# Register your models here.
class CustomerAdmin(admin.ModelAdmin):
    flist_display = ('id', 'name', 'qq', 'date', 'consultant')   # 展示欄位
    list_filter = ('date',)   # 檢索
    search_fields = ('qq', 'name') # 搜索
    raw_id_fields = ('consultant',)  #對fk可直接編輯多個
    filter_horizontal = ('tag',)   # manytomany 的覆選框
    list_editable = ('consultant',)  # 設置可編輯欄位
    list_per_page = 5  # 每一頁顯示條數
    readonly_fields = ('qq',) #只讀欄位
    readonly_table = False  # 只讀表
admin.site.register(models.Customer, CustomerAdmin)
admin.site.register(models.Product)

更多:http://docs.30c.org/djangobook2/chapter06/


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • [toc] 1.介紹abp 全稱:aspnetboilerplate。 官網:https://aspnetboilerplate.com/ 由美國人發起的開源項目。 web應用框架 2.abp如何工作 微服務框架,可以使用 net core版本,也可使用net framework兩種框架 3.運行D ...
  • 前言 Nginx是一款自由的、開源的、高性能的HTTP伺服器和 反向代理 伺服器;同時也是一個IMAP、POP3、SMTP代理伺服器;Nginx可以作為一個HTTP伺服器進行網站的發佈處理,另外Nginx可以作為反向代理進行負載均衡的實現。 Nginx使用基於事件驅動架構,使得其可以支持數以百萬級別 ...
  • if-else 作為每種編程語言都不可或缺的條件語句,我們在編程時會大量的用到。但if-else 一般不建議嵌套超過三層,如果一段代碼存在過多的 if-else 嵌套,代碼的可讀性就會急速下降,後期維護難度也大大提高。 ...
  • 一、前言 在實時性要求較高的場合中,CPU軟體執行的方式顯然不能滿足需求,這時需要硬體邏輯實現部分功能。要想使自定義IP核被CPU訪問,就必須帶有匯流排介面。ZYNQ採用AXI BUS實現PS和PL之間的數據交互。本文以PWM為例設計了自定義AXI匯流排IP,來演示如何靈活運用ARM+FPGA的架構。 ...
  • 問題描述 伺服器鏡像有寶塔面板 + Python2,用yum和pip3安裝Python3 + Flask + Gunicorn後,寶塔面板打不開了。報錯如下: 報錯早就刷上去了,找不回來,這段照搬別人的[^引用1],因為看著差不了多少。 其實我的情況跟引用1差不多,但是就是最後一步依然報錯。 修複 ...
  • 由於細節內容實在太多啦,所以只把部分知識點截圖出來粗略的介紹,每個小節點裡面都有更細化的內容! 內容簡介 這套書同時收錄了十多位阿裡技術人的訪談:從工程師到合伙人的多隆,6 年時間影響數億用戶的靖世,入選 MIT2017 年度 TR35 的王剛 &吳翰清,免試晉升為研究員的錢磊等,將為你展現不一樣的 ...
  • 當前測試人員的主要矛盾: Python基礎語法都看了學了幾遍了。 用不上,不會寫,網上的例子又大部分是面向開發人員的, 好多都是人工智慧,大數據,區塊鏈,或者數學演算法題。 偶爾有Selenium面向Web測試人員, 但是Selenium作為Python入門實例, 也不合適,因為還是太難了。 武散人的 ...
  • 題目 第一次做全英文編程題(辭彙量嚴重不足,還需多記單詞); 題目的大致意思就是說:輸入一個不超過20位的整數,將這個數乘以2,比較計算前和計算後的結果是否滿足題目的要求, 這個要求具體是指判斷組成這兩個數的具體數字出現的次數是否相等,例如:這個數為123456789,它乘以2之後得到2469135 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...