创建Django项目

 

创建一个HelloDjango项目

GitHub地址:https://github.com/liangdongchang/HelloDjango.git

1、在linux命令窗口终端下

  • 创建Django项目

    django-admin.py startproject HelloDjango
    sudo apt install tree
    tree HelloDjango/
    

2、在windows下

通过命令创建
先创建虚拟环境:python -m venv django_venv
然后导入django库:pip install django -i https://pypi.tuna.tsinghua.edu.cn/simple
最后使用命令创建:django-admin startproject my_django_project

3、在PyCharm中创建

file->New Project->Dhango

python创建Django项目_Django

4、默认工程结构

  • HelloDjango
    • init.py
      • 一个普通的包初始化模块
      • 可以在其中做全局的初始化动作
        • 例如:导入和初始化数据库
    • settings.py
      • Django项目的配置文件
      • 本项目引用的组件
      • 项目名
      • 数据库配置
      • 时间、语言
      • 静态文件访问地址和存储路径
    • urls.py
      • 维护项目的URL路由映射
        • 当客户端访问时由哪个模块进行响应
      • 使用views.py中的函数响应请求
        • url(r’^$’, views.home)
      • 将特定请求全部转交子模块中的urls.py处理
        • url(r’^axf/’, include(‘App.urls’, namespace=‘axf’))
    • wsgi.py
      • 定义WSGI的接口信息
      • 用于服务器部署
      • 通常使用系统默认设置即可
  • manage.py
    • Django用于管理本项目的命令行工具
    • 运行站点
    • 数据库自动生成

5、开启Django服务

在左下角找到Terminal,点击,在命令窗口中输入:

python manage.py runserver

python创建Django项目_Django_02

在浏览器输入服务器地址:http://127.0.0.1:8000/,可以看到服务器已经启动,按ctrl+c可以关闭服务器。

6、创建子应用

在命令窗口中输入:

python manage.py startapp MyApp

MyApp结构如下:

python创建Django项目_Django_03

  • 应用目录结构
    • init.py:其中暂无内容,使得app成为一个包
    • admin.py:管理站点模型的声明文件,默认为空
    • apps.py:应用信息定义文件,在其中生成了AppConfig,该类用于定义应用名等数据
    • models.py:添加模型层数据类文件
    • views.py:定义URL相应函数(路由规则)
    • migrations包:自动生成,数据迁移文件
    • tests.py:测试代码文件

7、注册子应用

在工程目录的settings.py中注册应用

python创建Django项目_Django_04

8、 定义数据模型(Models)

1、定义班级类

在MyApp目录下的models.py中插入如下代码:

# 班级类
class Grade(models.Model):

    # 班级名称
    gname = models.CharField(max_length=10)

    # 开班日期
    gdate = models.DateTimeField()

    # 女生数量
    ggirlnum = models.IntegerField()

    # 男生数量
    gboynum = models.IntegerField()

    # 是否已逻辑删除该班级
    isDelete = models.BooleanField(default=False)

    # 定义班级的打印输出信息
    def __str__(self):
        return self.gname
2、定义学生类
# 学生类
class Students(models.Model):
    # 学生姓名
    sname = models.CharField(max_length=20)

    # 学生性别
    sgender = models.BooleanField(default=True)

    # 学生年龄
    sage = models.IntegerField()

    # 备注信息
    sinfo = models.CharField(max_length=20)

    # 是否已逻辑删除该学生
    isDelete = models.BooleanField(default=False)

    # 学生所属的班级
    sgrade = models.ForeignKey(Grade,on_delete=None)

    def __str__(self):
        return self.sname

on_delete参数的各个值的含义:

on_delete=None,               # 删除关联表中的数据时,当前表与其关联的field的行为
on_delete=models.CASCADE,     # 删除关联数据,与之关联也删除
on_delete=models.DO_NOTHING,  # 删除关联数据,什么也不做
on_delete=models.PROTECT,     # 删除关联数据,引发错误ProtectedError
# models.ForeignKey('关联表', on_delete=models.SET_NULL, blank=True, null=True)
on_delete=models.SET_NULL,    # 删除关联数据,与之关联的值设置为null(前提FK字段需要设置为可空,一对一同理)
# models.ForeignKey('关联表', on_delete=models.SET_DEFAULT, default='默认值')
on_delete=models.SET_DEFAULT, # 删除关联数据,与之关联的值设置为默认值(前提FK字段需要设置默认值,一对一同理)
on_delete=models.SET,         # 删除关联数据,
 a. 与之关联的值设置为指定值,设置:models.SET(值)
 b. 与之关联的值设置为可执行对象的返回值,设置:models.SET(可执行对象)

9、数据迁移

  • 迁移的概念: 就是将模型映射到数据库的过程

  • 生成迁移

    python manage.py makemigrations
    
  • 执行迁移(在MyApp下的migrations包中)

    python manage.py migrate
    
    • 迁移过后,框架为我们自动生成了库表,Django默认自带的数据库是SQLite数据库;

    • 数据库文件生成路径为工程根目录下的db.sqlite3;

    python创建Django项目_Django_05

    • 生成的数据表结构如图

    python创建Django项目_Django_06

给数据库添加数据:
班级表:

python创建Django项目_Django_07

学生表:

python创建Django项目_Django_08

10、创建页面(Templates)

  • 修改HelloDjango下的settings.py中的模板配置

python创建Django项目_Django_09

  • 修改settings.py中的模板配置中的静态资源配置

    # 静态文件访问路由
    STATIC_URL = '/static/'
    
    # 静态文件存储目录:根目录/static/
    STATICFILES_DIRS = [
        os.path.join(BASE_DIR, 'static'),
    ]
    
  • 创建【根目录/static/img/】目录并放入一张wolf.jpg图片

    python创建Django项目_Django_10

  • 创建templates目录并在其中创建wolf.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>忧伤的狼</title>
    </head>
    <body>
    {# 加载静态资源 #}
    {% load static %}
    
    {# 加载图片位置 #}
    <img src="{% static 'img/wolf.jpg' %}" alt="我忧伤的眼神">
    </body>
    </html>
    

python创建Django项目_Django_11

11、定义路由映射(urls)

  • 在HelloDjango下的urls.py中插入如下代码

       from django.conf.urls import url
       from django.contrib import admin
    
    
       from MyApp import views
    
       urlpatterns = [
          url(r'^admin/', admin.site.urls),
          # http://127.0.0.1:8000/请求交由HelloDjango下的views中的index函数处理
          url(r'^wolf', views.wolf),
      ]
    
    

12、定义路由处理函数(Views)

  • 在MyApp下的views中插入如下代码:

    # http://127.0.0.1:8000/wolf/
    def wolf(request):
    # 渲染页面并呈现给用户
        return render(request,'wolf.html')
    

13、运行项目

终端执行如下命令中的一条

python manage.py runserver
python manage.py runserver [port]
python manage.py runserver [ip:port]
  • 默认执行起来的端口是8000
  • ip指定为0.0.0.0的时候,匹配本机的全部ip
  • 浏览器访问:localhost:8000

14、访问测试

python创建Django项目_Django_12

 

python创建Django项目_Django_13