Django獲取前端數(shù)據(jù)的實(shí)現(xiàn)方式
Django獲取前端傳輸?shù)臄?shù)據(jù)的幾種方式
獲取拼接在url上的數(shù)據(jù)
class UrlData(View):
def get(self, request):
# request的GET方法獲取拼接在url上數(shù)據(jù)的對象
dict1 = request.GET
# get方法根據(jù)key取value
name = dict1.get('name')
age = dict1.get('age')
return HttpResponse('get--{}--{}'.format(name, age))測試

獲取post請求提交的表單數(shù)據(jù)
def post(self, request):
# request的POST方法獲取表單數(shù)據(jù)對象
dict1 = request.POST
# 同樣是get獲取數(shù)據(jù)
name = dict1.get('name')
age = dict1.get('age')
return HttpResponse('post--{}--{}'.format(name, age))postman測試

獲取json數(shù)據(jù)
class JsonData(View):
def post(self, request):
# request的body方法獲取的是所有請求體的二進(jìn)制數(shù)據(jù)
json_body = request.body
print(json_body)
# 把請求體的二進(jìn)制數(shù)據(jù)轉(zhuǎn)換為json格式
json_data = json.loads(json_body)
#get方法鍵值對方式獲取值
name = json_data.get('name')
age = json_data.get('age')
gender = json_data.get('gender')
return HttpResponse('name: {},age: {}, gender: {}'.format(name, age, gender))
打印臺結(jié)果

測試

提取路徑數(shù)據(jù)
class LuJData(View):
""" 多傳一個變量age """
def get(self, request, age):
return HttpResponse('age: {}'.format(age))
注冊視圖時代碼
注意: 注冊時使用的轉(zhuǎn)換器里的變量名要 和 視圖里獲取數(shù)據(jù)的變量名的一致
urlpatterns = [
path('users/urldata/', views.UrlData.as_view()),
path('users/jsondata/', views.JsonData.as_view()),
# 使用int轉(zhuǎn)換器 <轉(zhuǎn)換器: 變量名>
# 變量名要和視圖函數(shù)添加的那個變量一樣的名字
path('users/lujdata/<int:age>/', views.LuJData.as_view()),
]測試

自定義轉(zhuǎn)換器
當(dāng)匹配url數(shù)據(jù)的時候有要求就可以使用自定義轉(zhuǎn)換器
工程目錄添加converters.py文件

自定義轉(zhuǎn)換器內(nèi)容
class MobileConverter:
# regex是正則表達(dá)式
regex = '1[3-9]\d{9}'
# 模仿Django自帶轉(zhuǎn)換器
def to_python(self, value):
return int(value)
def to_url(self, value):
return str(value)
在工程目錄的urls.py文件中注冊轉(zhuǎn)換器
# 參數(shù)1 為自定義轉(zhuǎn)換器類 參數(shù)2 起了一個別名 register_converter(MobileConverter, 'mobile')
注冊視圖函數(shù)時使用自定義轉(zhuǎn)換器
urlpatterns = [
path('users/urldata/', views.UrlData.as_view()),
path('users/jsondata/', views.JsonData.as_view()),
# 使用自定義轉(zhuǎn)換器
path('users/lujdata/<mobile:age>/', views.LuJData.as_view()),
]
測試

re_path匹配視圖時直接寫正則

如何從前端獲取數(shù)據(jù),post到后臺,再入數(shù)據(jù)庫呢
首先,從前端獲取值。這里需要你自己去掌握怎么取,我只是總結(jié)一下我這個過程!下邊我是想能同時上傳多個文件,所以才嵌套的循環(huán)。

然后,根據(jù)對應(yīng)的url,找到相關(guān)的model(這里,需要了解好你的數(shù)據(jù)庫屬性)。比如,這里是我想入庫的model:

好了,看完這個,我們?nèi)デ岸怂鵳ost到的assign(),這里我們需要掌握一下

# 篩選條件:name和task_tags,所以不能用get(),而是用filter()
condition_filter = {'task_tags':task_id, 'name':file_name}
# 得到一個Queryset
testrawdata_Qset = TestRawData.objects.using('oracle').filter(**condition_filter)
# 獲得Queryset的值(這里我需要的是id)
for testrawdata in testrawdata_Qset:
data_id = testrawdata.idget_or_create()就是入庫了,看看入庫結(jié)果(成功!):

總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python使用latexify模塊實(shí)現(xiàn)將代碼為數(shù)學(xué)公式
latexify 是一個輕量級的 Python 模塊,可以將 Python 代碼轉(zhuǎn)換為 LaTeX 格式的數(shù)學(xué)表達(dá)式,這篇文章就來和大家探索一下如何使用latexify模塊實(shí)現(xiàn)將代碼為數(shù)學(xué)公式吧2023-12-12
Python使用protobuf序列化和反序列化的實(shí)現(xiàn)
protobuf是一種二進(jìn)制的序列化格式,相對于json來說體積更小,傳輸更快,本文主要介紹了Python使用protobuf序列化和反序列化的實(shí)現(xiàn),感興趣的可以了解一下2021-05-05
python實(shí)現(xiàn)獲取序列中最小的幾個元素
這篇文章主要介紹了python實(shí)現(xiàn)獲取序列中最小的幾個元素,是非常實(shí)用的技巧,需要的朋友可以參考下2014-09-09
django 按時間范圍查詢數(shù)據(jù)庫實(shí)例代碼
這篇文章主要介紹了django 按時間范圍查詢數(shù)據(jù)庫實(shí)例代碼,分享了相關(guān)代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下2018-02-02
Django 接收Post請求數(shù)據(jù),并保存到數(shù)據(jù)庫的實(shí)現(xiàn)方法
今天小編就為大家分享一篇Django 接收Post請求數(shù)據(jù),并保存到數(shù)據(jù)庫的實(shí)現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07
OpenCV中Canny邊緣檢測的實(shí)現(xiàn)
本文主要介紹了OpenCV中Canny邊緣檢測的實(shí)現(xiàn),邊緣檢測一般是識別目標(biāo)圖像中亮度變化明顯的像素點(diǎn),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-07-07
Python全面解析json數(shù)據(jù)并保存為csv文件
這篇文章主要介紹了Python全面解析json數(shù)據(jù)并保存為csv文件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07
Python三目運(yùn)算符(三元運(yùn)算符)用法詳解(含實(shí)例代碼)
三元運(yùn)算符在Python里被稱為條件表達(dá)式,這些表達(dá)式基于真(true)/假(false)的條件判斷,在Python 2.4以上才有了三元操作,下面這篇文章主要給大家介紹了關(guān)于Python三目運(yùn)算符(三元運(yùn)算符)用法的相關(guān)資料,需要的朋友可以參考下2023-02-02

