Django入门

Day1 django环境安装

  • 创建虚拟环境

# step1 创建虚拟环境
python3 -m venv datawhale_django
# step2 mac进入虚拟环境
source ./datawhale_django/bin/activate
# step3 退出虚拟环境
deactivate
  • 安装包

pip3 install django
​pip3 install djangorestframework​​
pip3 install django-filter
pip3 install drf_spectacular
pip3 install django-debug-toolbar​​
pip3 install django_extensions

Day2 Django启动

  • 安装项目&app

# step1:创建django项目
django-admin startproject erp
# step2: erp项目中创建app,以下会创建两个app:data & purchase
django-admin startapp data
django-admin startapp purchase

需要将项目和已安装的app相关联,目的:在项目中找到对应的app
在这里插入图片描述

  • django项目启动&运行

# 以下两个命令在后面进行讲解
python3 manage.py makemigrations
python3 manage.py migration
# 项目运行
python3 manage.py runserver

Day3 数据库

在这里插入图片描述

  • 基本操作
    在这里插入图片描述

django数据库基础

常用字段

CharField: 用于存储字符串类型,有最大长度限制
IntegerField:用于存储整数类型
FloatField:用于存储浮点数类型
BooleanField:用于存储布尔类型
DateField:用于存储日期类型
DateTimeField:用于存储日期和时间类型
ImageField:用于存储图片类型
FileField:用于存储文件类型
ForeignKey:外键用于表示数据库之间的关联关系
OneToOneField:一对一用于表示一对一的关联关系
ManyToManyField:多对多,用于表示多对多的关联关系

常用配置

max_length:字段的最大长度限制,可以应用于多种不同的字段类型
verbose_name:字段的友好名称,便于在管理员后台可视化操作时使用
default:指定字段的默认值
null:指定字段是否可以为空,null=True设置允许该字段为NULL值
blank:指定在表单中输入时是否可以为空白
choices:用于指定字段的可选值枚举列表
class DeliveryMaterial(Model):
    """复核产品"""

    class Status(TextChoices):
        """状态"""

        QUALIFIED = ('qualified', '良品')
        UNQUALIFIED = ('unqualified', '不良品')

    status = CharField(max_length=32, choices=Status.choices, default=Status.QUALIFIED, verbose_name='状态')

TextChoices:用于在模型字段中创建可选择的,文本值的选项
related_name:指定在多对多等关系中反向使用的名称
on_delete:指定如果外键关联的对象被删除时应该采取什么操作

在app中创建相关的数据表

from django.db.models import *


# Create your models here.
## 产品分类表
class GoodsCategory(Model):
    """产品分类"""

    name = CharField(max_length=64, verbose_name='分类名称')
    remark = CharField(max_length=64, null=True, verbose_name='备注', blank=True)


## 产品表
class Goods(Model):
    """产品"""

    # 外键
    category = ForeignKey(GoodsCategory, on_delete=SET_NULL, related_name='goods_set', null=True, verbose_name='产品分类',
                          blank=True, )
    # on_delete

    number = CharField(max_length=32, verbose_name='产品编号')
    name = CharField(max_length=64, verbose_name='产品名称')
    barcode = CharField(max_length=32, null=True, blank=True, verbose_name='条码')
    spec = CharField(max_length=64, null=True, blank=True, verbose_name='规格')
    shelf_life_days = IntegerField(null=True, verbose_name='保质期天数')
    purchase_price = FloatField(default=0, verbose_name='采购价')
    retail_price = FloatField(default=0, verbose_name='零售价')
    remark = CharField(max_length=128, null=True, blank=True, verbose_name='备注')


"""
CharField:用于存储字符串类型,有最大长度限制
IntegerField:用于存储整数类型
FloatField:用于存储浮点数类型
BooleanField:用于存储布尔类型
DateField:用于存储日期类型
DateTimeField:用于存储日期和时间类型
ImageField:用于存储图片类型
FileField:用于存储文件类型
ForeignKey:外键 用于表示数据库表之间的关联关系
OneToOneField:一对一 用于表示一对一的关联关系
ManyToManyField:多对多 用于表示多对多的关联关系


max_length:字段的最大长度限制,可以应用于多种不同的字段类型。
verbose_name:字段的友好名称,便于在管理员后台可视化操作时使用。
default:指定字段的默认值。
null:指定字段是否可以为空。null=True 设置允许该字段为 NULL 值
blank:指定在表单中输入时是否可以为空白。
choices:用于指定字段的可选值枚举列表。
related_name:指定在多对多等关系中反向使用的名称。
on_delete:指定如果外键关联的对象被删除时应该采取什么操作。
"""

补充:如果希望添加的数据显示为中文,即:
在这里插入图片描述
,可以在models.py中表中添加如下信息:
在这里插入图片描述

  • 如果希望更改数据库配置,使用mysql,请使用如下方式
  • 在这里插入图片描述
    在这里插入图片描述

字段的增删改查

增加

在这里插入图片描述

修改

在这里插入图片描述

删除

在这里插入图片描述

在admin中注册数据集

from django.contrib import admin

# Register your models here.
from .models import *


admin.site.register(GoodsCategory)
admin.site.register(Goods)

表结构写好生成数据表之后,不建议修改表结构,问题:修改之后,重新执行语句,甚至删库之后,重新生成表结构,都会导致数据提交失败,暂时没找到方法修改数据表

添加管理员

python3 manager.py createsuperuser
# 登录 127.0.0.1:8080/admin

【补充】数据的增删改查

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述
补充:
在这里插入图片描述

视图函数

from django.shortcuts import render
from rest_framework.response import Response
from rest_framework import request
from .models import *
from rest_framework.decorators import api_view
from django.shortcuts import get_object_or_404


# Create your views here.

@api_view(['POST','GET'])
def FilterGoodsCategory(request):
    if request.method =='POST':
        data = request.data.get('分类名字')
    elif request.method == 'GET':
        data = request.query_params.get('分类名字')
    # data = request.data['分类名字']
    goods_category = get_object_or_404(GoodsCategory,name=data)
    print(goods_category)
    ans = Goods.objects.filter(category=goods_category).all().values()
    print(ans)
    return Response(ans)
  • rest_framework框架的相关用法等学过之后再来补充

rest_framework之Serialization

from rest_framework.serializers import *
序列化器的主要作用:

  • 序列化:将queryset和instance转换为json/xml/yaml返回给前端(将数据库中python对象的数据转换给前端能识别的数据)
  • 反序列化:与序列化相反,将前端传过来的json对象数据转换为python对象的数据,然后存入数据库中
    (1)序列化函数serializer.py
    在这里插入图片描述
    view函数中使用序列化
    在这里插入图片描述
    使用分三步:获取对象->创建序列化函数->提取数据
    在这里插入图片描述

rest_framework之DRF(ModelViewSet)

from rest_framework.viewsets import ModelViewSet
模型类中提供了默认的增删改查功能
在这里插入图片描述
from rest_framework.decorators import action

@action 是 Django REST framework 中的一个装饰器,用于将自定义函数转换为视图集的一个动作。@action 装饰器提供了一种定义自定义函数的方式,这些函数并不直接对应于标准的 CRUD 操作(Create-Read-Update-Delete),而是实现一些其他的自定义行为或业务逻辑。
在这里插入图片描述

rest_framework之DefaultRouter

from rest_framework import routers
合直接在urlpatterns中写的效果一样
在这里插入图片描述
使用routers.DefaultRouter()​创建了一个默认的路由器对象,并使用router.register()​方法注册了一个视图集,GoodsCategoryViewSet​。这样可以自动为这个视图集生成对应的URL路由,并将其添加到urlpatterns​中。

  • rest_framework相关的东西还要好好看看

其他(先放这里,后面修改)

注册功能,首先需要一个前端页面
在这里插入图片描述

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值