1. 程式人生 > 其它 >C語言itoa()函式和atoi()函式詳解(整數轉字元)

C語言itoa()函式和atoi()函式詳解(整數轉字元)

目錄

  1. 虛擬環境

  2. django路由層版本區別

  3. 檢視函式返回值

  4. JsonResponse物件

  5. 上傳檔案

  6. request方法

  7. FBV與CBV

  8. CBV源剖析

  9. 模板語法傳值

內容

虛擬環境

我們在實際開發工作中,針對不同的專案需要為其配備對應的直譯器環境

諸多專案在你的機器上如何無障礙的開啟並執行

  • 方式1:把所有需要用到的模組全部下載下來,如果有相同模組不同版本每次都重新下載替換
  • 方式2:提前準備好多個直譯器環境,針對不同的專案切換即可

建立虛擬環境:相當於下載一個全新的直譯器

識別虛擬環境:檔案目錄中有一個venv資料夾

如何切換環境:選擇不用的直譯器即可,不要再次勾選new enviroment...

django版本區別

路由層

django1.x與2.x、3.x有些許區別

路由匹配的方法不一樣

  • url():支援正則
  • path():第一個引數不支援正則,寫什麼是什麼

如果想使用正則,也提供了方法

from django.urls import path,re_path

re_path(r'^index/', index)
View Code

path方法提供了轉換器功能

path('index/<int_id>/', index)

匹配對應位置的資料並且自動轉換型別

有五種轉換器可供選擇

檢視函式返回值

檢視函式必須返回一個HttpResonse物件

HttpResponse

render

redirect(多繼承)

JsonResponse物件

user_dict = {'name': 'zhou', 'pwd': 123, 'hobby': '好好學習'}

return JsonResponse(user_dict,json_dumps_params={'ensure_ascii':False})
View Code

如果序列化的不是字典

user_list = [11,22,33,44,55]

return JsonResponse(user_list,safe=False)

為什麼使用JsonResponse而不是原始的json模組,因為django對json序列化的資料型別的範圍做了擴充

上傳檔案

form表單上傳的資料中如果含有檔案,那麼需要做以下幾件事

  1. method必須是post
  2. enctype必須修改為multipart/form-data 預設是application/x-www-form-urlencoded
  3. 後端需要使用request.FILES獲取(POST只會拿到檔名)

file_obj = request.FILES.get('my_file')

print(file_obj.name):檢視檔名

上傳檔案(支援for迴圈)

with open(file_obj.name,'wb') as f:
    for line in file_obj:
        f.write(line)
    
View Code

django會根據資料型別的不同自動幫你封裝到不同的方法中

request方法

  • request.method
  • request.POST
  • request.GET
  • request.FILES
  • request.body:存放的是接收過來的最原始的二進位制資料,request.POST、request.GET、request.FILES這些獲取資料的方法其實都是從body中獲取資料並解析存放的
  • request.path:獲取路徑
  • request.path_info:獲取路徑
  • request.get_full_path():獲取路徑並且還可以獲取到路徑後面攜帶的引數

FBV與CBV

FBV:基於函式的檢視

url(r'^index/',函式名)

CBV:基於類的檢視

from django import views

class MyLoginView(views.View):

    def get(self, request):

    return HttpResponse("from CBV get view")

    def post(self, request):

    return HttpResponse("from CBV post view")
View Code

url(r'^ab_cbv/',views.MyLoginView.as_view())

如果請求方式是GET,則會自動執行類裡面的get方法

如果請求方式是POST 則會自動執行類裡面的post方法

CBV原始碼剖析

切入點:路由匹配

類名點屬性as_view並且還加了括號

as_view可能是普通的靜態方法,as_view可能是繫結給類的方法

物件查詢屬性的順序

先從物件自身開始,再從產生物件的類,之後是各個父類

MyLoginView.as_view():先從我們自己寫的MyLoginView中查詢,沒有再去父類Views中查詢

函式名加括號執行優先順序最高

url(r'^ab_cbv/', views.MyLoginView.as_view())

專案一啟動就會執行as_view方法,檢視原始碼發現返回了一個閉包函式名view

== url(r'^ab_cbv/', views.view)

CBV與FBV在路由匹配本質是一樣的

路由匹配成功之後執行view函式

執行dispatch方法(需要注意查詢的順序)

模板語法傳值

django提供的模板語法只有兩個符號

  • {{ }}:主要用於變數相關操作(引用)
  • {% %}:主要用於邏輯相關操作(迴圈、判斷)

傳值的兩種方式

傳值方式1:指名道姓的傳,適用於資料量較少的情況,節省資源

return render(request,'ab_temp.html',{'name':name})

傳值方式2:打包傳值,適用於資料量較多的情況,浪費資源

return render(request, 'ab_temp.html', locals())

locals() 將當前名稱空間中所有的名字全部傳遞給html頁面

2.傳值的範圍

  • 基本資料型別都可以
  • 函式名:模板語法會自動加括號執行並將函式的返回值展示到頁面上,但是不支援傳參(模板語法會自動忽略有參函式)
  • 檔名:直接顯示檔案IO物件
  • 類名:自動加括號例項化成物件
  • 物件名:直接顯示物件的地址,並且具備呼叫屬性和方法的能力

django模板語法針對容器型別的取值只有一種方式>>>:句點符 既可以點key也可以點索引,django內部自動識別