清秋2018

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

Django基础-01篇

一、Django介绍

flask,FastApi是轻量级服务端开发框架

Django是重量级服务端开发框架

ORM:封装了数据库操作

form:校验请求数据

安装Django:

pip install django==2.1.7  #指定版本安装,默认是安装最新版本

注意:最新版本的Django对mysql版本也有要求

二、Django命令

1.创建项目命令:django-admin startproject test_django

2.启动项目命令:

  python manage.py runserver  默认端口启动8000

  python manage.py runserver  0.0.0.0:8002   指定端口启动,别人也可以访问

  python manage.py runserver  127.0.0.1:8002 指定端口启动,只能自己访问

3.创建子模块:python manage.py startapp user

4.创建表结构:

  python manage.py makemigrations  #生成建表/更新表的py文件

  python manage.py migrate  #根据上面命令生成的py文件,来建表/更新表

三、Django项目介绍

3.1 项目整体结构

 

 

3.2 urls.py

该文件是用来配置url的

复制代码
from django.contrib import admin
from django.urls import path
from user import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('index/', views.index),
    path('get_sign', views.get_sign),
    path('category_view', views.category_view),
    path('category/<int:id>', views.category),
    path('article/<int:id>', views.detail),
]
复制代码

3.3 settings.py

该文件是配置文件,数据库等配置

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
import os
 
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
 
 
# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/2.1/howto/deployment/checklist/
 
# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = '^28j+9pchzsrhs0w1p5n9hz+bp&4)dek8n8zd1+y0e+g4vvpxb'
 
# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True
 
ALLOWED_HOSTS = ['*'#设置允许那些ip可以进行访问,如果允许所有,则写成['*']
 
 
# Application definition
 
INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'user',
    'order'
]
 
MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
# 中间件用到
 
ROOT_URLCONF = 'sky.urls'
 
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',
            ],
        },
    },
# 前后端不分离时用到
 
WSGI_APPLICATION = 'sky.wsgi.application'
 
 
# Database
# https://docs.djangoproject.com/en/2.1/ref/settings/#databases
 
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
# 数据库配置
 
 
# Password validation
# https://docs.djangoproject.com/en/2.1/ref/settings/#auth-password-validators
 
AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    },
]
 
 
# Internationalization
# https://docs.djangoproject.com/en/2.1/topics/i18n/
 
LANGUAGE_CODE = 'zh-Hans'  # 设置语言,'en-us':英文,'zh-Hans':中文
 
TIME_ZONE = 'Asia/Shanghai'  # 设置时区,'UTC':标准时区,'Asia/Shanghai':亚洲上海时区
 
USE_I18N = True
 
USE_L10N = True
 
USE_TZ = False  # 设置是否使用标准时区时间,我们设置为False
 
 
# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/2.1/howto/static-files/
 
STATIC_URL = '/static/'
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]  # 设置静态文件目录

  

3.4 wsgj.py

该文件是用来部署用的

3.5 manage.py

项目管理文件

3.6 models.py

操作数据库文件

复制代码
from django.db import models

# Create your models here.
# 创建表结构的地方

class BasicModel(models.Model):
    create_time = models.DateTimeField(verbose_name='创建时间', auto_now_add=True)
    update_time = models.DateTimeField(verbose_name='修改时间', auto_now=True)

    class Meta:
        abstract = True


class Category(BasicModel):
    name = models.CharField(verbose_name='分类名称',max_length=50,unique=True)


    class Meta:
        db_table = 'category'
        verbose_name = '文章分类'  # 在admin后台显示表名
        verbose_name_plural = verbose_name  # 在admin后台显示表名的复数形式

        ordering = ['id']  # 根据某些字段进行升序排序
        # ordering = ['-id']  # 有- 根据某些字段进行降序排序

    # 定义下面的函数实现在admin后台中展示字段,从而代替展示的 tablename objects
    def __str__(self):
        return self.name

class Article(BasicModel):
    title = models.CharField(verbose_name='文章标题', max_length=50)
    content = models.TextField(verbose_name='文章内容')  # 长文本
    read_count = models.IntegerField(verbose_name='阅读次数', default=0)
    category = models.ForeignKey(Category, on_delete=models.PROTECT, verbose_name='分类')

    class Meta:
        db_table = 'article'
        verbose_name = '文章'
        verbose_name_plural = verbose_name

    def __str__(self):
        return self.title
复制代码

代码写好后,分别执行以下命令,就可以生成表结构

 python manage.py makemigrations

 python manage.py migrate

Django 内嵌了sqllite,默认就是将表创建在sqllite中

如果想要连接mysql等其他数据库,需要自己在settings.py文件中配置

关联删除模式:

#外键删除操作模式
    #models.DO_NOTHING:不受任何影响
    #models.CASCADE:关联的数据也会被删除,分类被删除,引用分类的文章也会被删除
    #models.SET:传入一个方法名,用方法逻辑处理
    #models.SET_DEFAULT:删除了,设置为默认值,要该字段有默认值
    #models.SET_NULL:删除了,直接设置为空,要该字段可为空
    #models.PROTECT#受保护,不能删除,只要这个分类下有文章,就不能删除这个分类

3.7 views.py

是用来做逻辑处理的文件

复制代码
from django.shortcuts import render
from django.shortcuts import HttpResponse
from . import models

# Create your views here.
# 写逻辑的地方

def index(request):
    # return HttpResponse('hello django!')
    categories = models.Category.objects.all()
    articles = models.Article.objects.all()
    title = 'my blog'
    return render(request, 'index.html', {'title': title, 'categories': categories, 'articles': articles})  # 第三个参数,把值传到html页面上

def get_sign(request):
    print(request.method)  # 请求方式
    print(request.body)  # 请求体
    print(request.META)  # 请求头
    print(request.GET)  # url里面的参数都在GET   url? a=1&b=2
    print(request.POST)  # POST中的参数  k-v,k1=v1
    print(request.FILES)  # 文件
    print(request.COOKIES)  # cookies
    return HttpResponse('sign')

def category_view(request):
    c = models.Category.objects.all() # 查询所有的数据
    for i in c:
        print(i.name)
        print(i.create_time)
        print(i.update_time)
    print('=====================')
    s = models.Category.objects.get(id=3)  # 使用get,必须要保证返回的只有1条结果
    print(s.name)
    f = models.Category.objects.filter(name='java', id=3)  # 进行过滤,返回多条结果

    result = models.Category.objects.filter(name='mysql').exists()  # 使用过滤后,利用exists方法判断是否存在
    print(result)
    result = models.Category.objects.filter(name='java').count()  # 使用过滤后,利用count方法统计返回条数
    print(result)
    return HttpResponse('ok')

def category(request, id):
    categories = models.Category.objects.all()
    articles = models.Article.objects.filter(category_id=id)
    # print(articles.first())  # 返回第一个
    # print(articles.last())  # 返回最后一个
    return render(request, 'category.html', {'articles': articles, 'categories': categories})

def detail(request,id):
    article = models.Article.objects.get(id=id)
    counts = article.read_count
    counts += 1

    return render(request, 'detail.html', {'article': article, 'counts': counts})
复制代码

3.8 ORM操作数据库

复制代码
def category_view(request):
    c = models.Category.objects.all() # 查询所有的数据
    for i in c:
        print(i.name)
        print(i.create_time)
        print(i.update_time)
    print('=====================')
    s = models.Category.objects.get(id=3)  # 使用get,必须要保证返回的只有1条结果
    print(s.name)
    f = models.Category.objects.filter(name='java', id=3)  # 进行过滤,返回多条结果

    result = models.Category.objects.filter(name='mysql').exists()  # 使用过滤后,利用exists方法判断是否存在
    print(result)
    result = models.Category.objects.filter(name='java').count()  # 使用过滤后,利用count方法统计返回条数
    print(result)
    return HttpResponse('ok')
复制代码

5.9 test.py

测试代码

注意:需要手动加入Django配置,才可以测试

 

posted on   清秋2018  阅读(164)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· winform 绘制太阳,地球,月球 运作规律
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示