django框架單表操作之增刪改實例分析
更新時間:2019年12月16日 10:24:49 作者:dawn-liu
這篇文章主要介紹了django框架單表操作之增刪改,結(jié)合實例形式分析了Django框架前臺數(shù)據(jù)操作提交與后臺處理相關(guān)實現(xiàn)技巧,需要的朋友可以參考下
本文實例講述了django框架單表操作之增刪改。分享給大家供大家參考,具體如下:
首先找到操作的首頁面
代碼如下
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css" rel="external nofollow" >
<title>書列表</title>
</head>
<body>
<div class="container">
<a href="/add_book/" rel="external nofollow" class="btn btn-success">添加新書</a>
<div class="panel panel-primary">
<div class="panel-heading">書籍管理</div>
<div class="panel-body">
<table class="table table-bordered table-striped">
<thead>
<tr>
<th>#</th>
<th>書名</th>
<th>操作</th>
</tr>
</thead>
<tbody>
{% for book in book_list %}
<tr data-id="{{ book.id }}">
<td>{{ forloop.counter }}</td>
<td>{{ book.title }}</td>
<td><a href="/delete_book/?id={{ book.id }}" rel="external nofollow" class="btn btn-danger">刪除</a>
<a href="/edit_book/?id={{ book.id }}" rel="external nofollow" class="btn btn-info">修改</a></td> 此處的?id可以改成 ?iid,或者其他的名稱,在views.py文件里對函數(shù)edit_book修改即可edit_id=request.GET.get('iid')
</tr> {% endfor %} </tbody> </table> </div> </div> </div> </body> </html>

主頁:

之后,根據(jù)不同的操作指向不同的頁面,這部分功能需要修改urls.py
from django.conf.urls import url
from django.contrib import admin
from app01 import views
urlpatterns = [
# url(r'^admin/', admin.site.urls),
url(r'^home/',views.home),
url(r'^index/',views.index),
url(r'^login/',views.login),
url(r'^book_list/',views.book_list),
#添加新書
url('^add_book/',views.add_book),
#刪除書籍
url('^delete_book/',views.delete_book),
#修改書籍
url(r'^edit_book/',views.edit_book),
]
其次,不同操作指向不同的頁面
add_book.html
主要的部分
<form class="form-horizontal" action="/add_book/" method="post"> #提交到 add_book
<div class="form-group">
<label for="inputbookname" class="col-sm-2 control-label">書籍名稱</label>
<div class="col-sm-3">
<input type="text" class="form-control" id="inputbookname" name="book_name">
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-default">添加新書</button>
edit_book.html
主要部分
<form class="form-horizontal" action="/edit_book/" method="post">
<input hidden type="text" name="book_id" value="{{ book.id }}">
<div class="form-group">
<label for="inputbookname" class="col-sm-2 control-label">書籍名稱</label>
<div class="col-sm-3">
<input type="text" class="form-control" id="inputbookname" name="book_name" value="{{ book.title }}">
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-default">提交修改</button>
刪除在后臺執(zhí)行
最后后臺函數(shù)的配置views.py
def book_list(request):
#找到所有的書
books=models.Book.objects.all()
return render(request,"book_list.html",{"book_list":books})
def add_book(request):
#判斷是否為post
if request.method=="POST":
new_book_name=request.POST.get("book_name")
#去數(shù)據(jù)庫創(chuàng)建一條記錄
models.Book.objects.create(title=new_book_name)
#跳轉(zhuǎn)回之前書籍展示的頁面
return redirect("/book_list/")
#返回一個頁面讓用戶填寫新書的相關(guān)信息
return render(request,"add_book.html")
def delete_book(request):
#取到要刪除書的id,如何從get請求獲取數(shù)據(jù)
delete_id=request.GET.get("id")
#根據(jù)id值去數(shù)據(jù)庫取對應(yīng)的數(shù)據(jù)
models.Book.objects.get(id=delete_id).delete()
return redirect("/book_list/")
def edit_book(request):
if request.method=="POST":
#取到書的id
book_id=request.POST.get("book_id")
#用戶修改后的名稱
new_book_title=request.POST.get("book_name")
#在數(shù)據(jù)庫中查找id對應(yīng)的記錄
book_obj= models.Book.objects.get(id=book_id)
#將用戶的名稱給修改到這個id中
book_obj.title=new_book_title
#保存提交
book_obj.save()
#跳轉(zhuǎn)到書列表的頁面
return redirect("/book_list/")
edit_id=request.GET.get('id')
book=models.Book.objects.get(id=edit_id)
return render(request,"edit_book.html",{"book":book}) #以字典的方式傳遞變量
#note:
# 對書籍進行編輯,是通過book_list頁面?zhèn)鬟fid(或者iid),在對上面的函數(shù)獲取其id時得到edit_id,知道其id和title就可以進行修改
希望本文所述對大家基于Django框架的Python程序設(shè)計有所幫助。
您可能感興趣的文章:
- django框架使用views.py的函數(shù)對表進行增刪改查內(nèi)容操作詳解【models.py中表的創(chuàng)建、views.py中函數(shù)的使用,基于對象的跨表查詢】
- Django-Model數(shù)據(jù)庫操作(增刪改查、連表結(jié)構(gòu))詳解
- Django中ORM表的創(chuàng)建和增刪改查方法示例
- python Django連接MySQL數(shù)據(jù)庫做增刪改查
- Django數(shù)據(jù)庫操作的實例(增刪改查)
- 利用Django提供的ModelForm增刪改數(shù)據(jù)的方法
- python django 增刪改查操作 數(shù)據(jù)庫Mysql
- 使用Django開發(fā)簡單接口實現(xiàn)文章增刪改查
- 對Django的restful用法詳解(自帶的增刪改查)
相關(guān)文章
Python數(shù)據(jù)分析之Excel和Text文件的讀寫操作方法
Python操作Excel分為兩個主要形式,讀寫和交互式操作,可以用不同的第三方工具,下面這篇文章主要給大家介紹了關(guān)于Python數(shù)據(jù)分析之Excel和Text文件的讀寫操作方法,需要的朋友可以參考下2024-08-08
詳解Python 定時框架 Apscheduler原理及安裝過程
Apscheduler是一個非常強大且易用的類庫,可以方便我們快速的搭建一些強大的定時任務(wù)或者定時監(jiān)控類的調(diào)度系統(tǒng),這篇文章主要介紹了Python 定時框架 Apscheduler ,需要的朋友可以參考下2019-06-06
PyTorch快速搭建神經(jīng)網(wǎng)絡(luò)及其保存提取方法詳解
本篇文章主要介紹了PyTorch快速搭建神經(jīng)網(wǎng)絡(luò)及其保存提取方法詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-04-04

