1. 程式人生 > 其它 >django學習(一)

django學習(一)

目錄

作業講解

1.資料展示
2.給按鈕附加功能
3.在路由匹配中獲取到使用者想要編輯的資料主鍵值
4.點選編輯按鈕 應該展示當前資料的編輯頁面
	通過無名或者有名分組獲取到使用者想要編輯的資料主鍵值
  獲取對應的資料物件傳遞給頁面 展示給使用者看並提供編輯功能
5.編寫刪除功能
	路由設計跟編輯功能一致

def home(request):
    data_queryset = models.User.objects.filter()  # [obj1,obj2,obj3]
    return render(request,'home.html',{'data_queryset':data_queryset})


def edit_data(request,edit_id):
    # 獲取使用者編輯的資料物件
    edit_obj = models.User.objects.filter(id=edit_id).first()
    if not edit_obj:
        return HttpResponse('當前使用者編號不存在')
    if request.method == 'POST':
        # 獲取新的資料
        username = request.POST.get('username')
        password = request.POST.get('password')
        # 修改原資料 方式1
        # models.User.objects.filter(id=edit_id).update(name=username,pwd=password)
        # 修改原資料 方式2
        edit_obj.name = username
        edit_obj.pwd = password
        edit_obj.save()
        # 重定向到展示頁
        return redirect('home_view')  # 括號內也可以直接寫反向解析的別名 不適用於無名有名反向解析
    # 將待編輯的資料物件傳遞給頁面展示給使用者看
    return render(request,'edit.html',{'edit_obj':edit_obj})


def delete_data(request,delete_id):
    # 獲取想要刪除的物件資料
    edit_queryset = models.User.objects.filter(id=delete_id)
    if not edit_queryset:
        return HttpResponse("使用者編號不存在")
    edit_queryset.delete()
    return redirect('home_view')

虛擬環境

我們在實際開發工作中 針對不同的專案需要為其配備對應的直譯器環境
	eg:
    專案1 
    	django2.2 pymysql3.3 requests1.1
    專案2 
    	django1.1
    專案3
    	flask
諸多專案在你的機器上如何無障礙的開啟並執行
	方式1:把所有需要用到的模組全部下載下來 如果有相同模組不同版本每次都重新下載替換
  方式2:提前準備好多個直譯器環境 針對不同的專案切換即可
 
# 建立虛擬環境 
	相當於在下載一個全新的直譯器
# 識別虛擬環境
	檔案目錄中有一個venv資料夾
# 如何切換環境
	選擇不用的直譯器即可 全文不要再次勾選new enviroment...

django版本區別

# 路由層
	django1.x與2.x、3.x有些許區別
  1.路由匹配的方法不一樣呀
  	url()	支援正則					path() 第一個引數不支援正則
    如果想使用正則 也提供了方法		
    from django.urls import path,re_path
    
	2.path方法提供了轉換器功能
  	path('index/<int:id>/', index)
    匹配對應位置的資料並且自動轉換型別
    '''有五種轉換器可供選擇'''
#1、五個內建轉化器
	- str:匹配除了路徑分隔符(/)之外的非空字串,這是預設的形式
    - int:匹配正整數,包括0
    - slug:匹配字母、數字、下劃線以及橫槓組成的字串
    - uuid:匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00
    - path:匹配任何非空字串,包含了路徑分隔符(/),不能用"?"
        
#2、示例:
	- path('login/<int:year>', views.login),
    - path('login/<str:name>', views.login),
    - path('login/<path:p>',views.article),
    
#3、高階示例:
	- 實現匹配這種路徑:http://127.0.0.1:8000/jason/p/4444.html
    - path('<str:name>/p/<int:id>.html', views.article),
    - re_path(r'^(?P<name>.*?)/p/(?P<id>\d+).html$', views.login)
	- url(r'^(?P<name>.*?)/p/(?P<id>\d+).html$', views.login)
    # url在2.x之後的版本不建議使用,可以使用re_path代替
    
#4、轉化器不能在re_path中使用
————————————————
版權宣告:本文為CSDN博主「知行合一cc」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處連結及本宣告。
原文連結:https://blog.csdn.net/weixin_49111957/article/details/109754240

檢視函式返回值

# 檢視函式必須返回一個HttpResonse物件
	HttpResponse
  	class HttpResponse(...):
      pass
  render
  	def render(...):
      return HttpResponse(...)
  redirect
  	def redirect(...):
      # 多繼承

JsonResponse物件

user_dict = {'name': 'jason', 'pwd': 123, 'hobby': '好好學習'}
return JsonResponse(user_dict,json_dumps_params={'ensure_ascii':False})

class JsonResponse(HttpResponse):
	def __init__(self, data,json_dumps_params=None, **kwargs):
		data = json.dumps(data, **json_dumps_params)
  
"""為什麼使用JsonResponse還不是原始的json模組"""
django對json序列化的資料型別的範圍做了擴充	
	回憶之前我們自己擴充套件的序列化方法

from表單上傳檔案

from表單上傳的資料中如果含有檔案那麼需要做以下幾件事情
1.method必須是post
2.enctype必須修改為multipart/form-data
	預設是application/x-www-form-urlencoded
3.後端需要使用request.FILES獲取
# 都將哦會根據資料型別的不同自動幫忙封裝到不同的方法中

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")
	url(r'^ab_cbv/', views.MyLoginView.as_view())
 	"""
 	如果請求方式是GET 則會自動執行類裡面的get方法
 	如果請求方式是POST 則會自動執行類裡面的post方法
 	"""

CBV原始碼剖析

"""
django提供的模板語法只有兩個符號
	{{}}:主要用於變數相關操作(引用)
	{%%}:主要用於邏輯相關操作(迴圈、判斷)
"""


1.傳值的兩種方式
	# 傳值方式1:指名道姓的傳  適用於資料量較少的情況       節省資源
  # return render(request, 'ab_temp.html', {'name':name})
  # 傳值方式2:打包傳值  適用於資料量較多的情況(偷懶)     浪費資源
  '''locals() 將當前名稱空間中所有的名字全部傳遞給html頁面'''
  return render(request, 'ab_temp.html', locals())

2.傳值的範圍
	基本資料型別都可以
  函式名
  	模板語法會自動加括號執行並將函式的返回值展示到頁面上
    不支援傳參(模板語法會自動忽略有參函式)
 	檔名
  	直接顯示檔案IO物件
  類名
  	自動加括號例項化成物件
  物件名
  	直接顯示物件的地址 並且具備呼叫屬性和方法的能力
  
# django模板語法針對容器型別的取值 只有一種方式>>>:句點符
	既可以點key也可以點索引  django內部自動識別
  	{{ data1.info.pro.3.msg }}