IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> django模型 -> 正文阅读

[Python知识库]django模型

创建一个 Django 项目与一个应用程序

django-admin startproject webtest 
cd webtest 
python manage.py startapp book 

在生成的webtest/webtest/init.py文件下添加

import pymysql 
pymysql.install_as_MySQLdb()

打开 settings.py 文件,修改 INSTALLED_APPS 以完成对应用的配置

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'book'
]

创建一个数据库,数据库protest必须先存在才能使用

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'protest', # 数据库名
        'HOST':'localhost',
        'USER':'root',
        'PASSWORD':'123456789',
        'PORT':3306
    }
}

启动服务 如果不加IP和端口号,url默认127.0.0.1 端口号为8000

pythonmanage.pyrunserver 

,打开浏览器并在地址栏输入 http://127.0.0.1:8000,显示如下效果则表示成功

定义与创建模型

设计并生成数据表
生成的数据表名称默认为 应用名_类名, 如果想修改名称可在类的下面在建立一个类Meta, 执行verbose_name_plural=“表名” 对表名进行修改

from django.db import models
# 自定义类:图书类
class BookInfo(models.Model):
    bname = models.CharField("书名",max_length=20)
    bpub_date = models.DateField("出版日期")
    bpage = models.IntegerField(verbose_name='总页数',default=0)
    is_delete=models.BooleanField(default=False)
    # 定义str
    def __str__(self):
        return self.bname + "," + str(self.bpub_date) + "," + str(self.bpage)
  # class Meta:
       # 2.修改表名
       # verbose_name_plural = "图书"

# 自定义作者类
class AuthorInfo(models.Model):
    aname = models.CharField("姓名",max_length=10)
    agender = models.BooleanField(verbose_name='性别', default=True)
    acontent = models.CharField(verbose_name='简介', max_length=200)
    abook = models.ForeignKey('BookInfo', verbose_name='相关书籍')
    is_delete=models.BooleanField(default=False)
       # # 定义str
    def __str__(self):
        return self.aname

生成数据表,则需要先执行如下命令用于生成迁移文件和执行迁移文件

python manage.py makemigrations
pythonmanage.pymigrate

添加数据,可就直接到MySQL下直接添加数据,也可在python脚本下添加数据,以下是直接在MySQL下添加数据的代码
向book_bookinfo添加数据

insert into book_bookinfo(bname,bpub_date,bpage,is_delete) values ("Python 从入门到精通","2017-6-3",431,0), 
("Python 经典案例 100 例","2018-9-7",154,0), 
("疯狂的程序员","2007-3-4",310,0);

向book_authorinfo添加数据

insert into book_authorinfo(aname,agender,acontent,is_delete,abook_id)
values ("李军",1,"实战开发",0,1), 
("叶维忠",1,"大学教授",0,1), 
("方哥",1,"实战开发",0,2), 
("叶子美",0,"大学讲师",0,2), 
("绝影",1,"博客博主",0,3);

图书信息显示

通过访问“http://127.0.0.1:8000/index”展示出数据。首先,找到 webtest/ webtest 目录下的 urls.py 文件,如下内容:

from django.conf.urls import url,include 
from django.contrib import admin
urlpatterns=[ 
	url(r'^admin/',admin.site.urls),
	url(r"^",include("book.urls")) ] 

创建 templates 目录,并创建 templates/mybook/index.html 文件
此时需要在settings.py文件下修改配置路径

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',
            ],
        },
    },
]

在 webtest/book/views.py 文件下编写视图函数代码

from django.shortcuts import render
from .models import BookInfo
# Create your views here.
def index(request):
#1.获取所有图书信息
    books = BookInfo.objects.all()
    # data=[1,2,3,4,5]
# #2.获取模板文件
    return render(request,"book/index.html",{"books":books})

编写视图函数完成后,配置主路由和子路由url
子路由: book/urls.py 文件进行 url 配置(自己创建)

from django.conf.urls import url
from .views import *
urlpatterns=[
    url(r"^index/",index),# 显示图书信息
]

主路由配置:在webtest/webtest/urls.py文件下

from django.contrib import admin
from django.conf.urls import url,include
urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^book/', include("book.urls")),
]

最后,来把上述数据库中的关于图书的信息显示在网页中

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<h1>hello world</h1>
<ul>
{%for book in books%}
    <li>{{book.bname}}</li>
    {% endfor %}
</ul>
</body>
</ht

完成以上步骤后在在页面上输入相应url即可展示数据.
抽象函数: 对于表格的创建和每一次修改都应该有时间记录,因此可以使用抽象函数创建一个新的数据表来记录这些时间,创建一个新的目录db下创建一个新py文件
注意:不能直接运行直接使用

from django.db import models

class BaseModel(models.Model):
    # 添加时间 修改时间 is_delete
    id_delete=models.BooleanField(verbose_name="是否可用",default=False)
    create_time = models.DateTimeField(verbose_name="添加时间",auto_now=True)
    update_time = models.DateTimeField(verbose_name="修改时间",auto_now_add=True)
    class Meta:
        abstract=True

添加一个视图函数和抽象函数搭配使用

def add(request):
    b1=BookInfo()
    b1.bname="简爱"
    b1.bpub_date='2001-1-1'
    b1.bkind="小说类"
    b1.save()
    return HttpResponse("hello add")

创建抽象函数后,可在models文件中导入使用,数据类直接继承抽象函数

class BookInfo(BaseModel):

过滤器: 可根据条件过滤掉不需要显示的内容

books = BookInfo.objects.filter(is_delect=0)
  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2021-12-15 18:15:03  更:2021-12-15 18:16:58 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/6 20:24:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码