创建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
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’))
- 维护项目的URL路由映射
- wsgi.py
- 定义WSGI的接口信息
- 用于服务器部署
- 通常使用系统默认设置即可
- init.py
- manage.py
- Django用于管理本项目的命令行工具
- 运行站点
- 数据库自动生成
5、开启Django服务
在左下角找到Terminal,点击,在命令窗口中输入:
python manage.py runserver
在浏览器输入服务器地址:http://127.0.0.1:8000/,可以看到服务器已经启动,按ctrl+c可以关闭服务器。
6、创建子应用
在命令窗口中输入:
python manage.py startapp MyApp
MyApp结构如下:
- 应用目录结构
- init.py:其中暂无内容,使得app成为一个包
- admin.py:管理站点模型的声明文件,默认为空
- apps.py:应用信息定义文件,在其中生成了AppConfig,该类用于定义应用名等数据
- models.py:添加模型层数据类文件
- views.py:定义URL相应函数(路由规则)
- migrations包:自动生成,数据迁移文件
- tests.py:测试代码文件
7、注册子应用
在工程目录的settings.py中注册应用
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;
- 生成的数据表结构如图
-
给数据库添加数据:
班级表:
学生表:
10、创建页面(Templates)
- 修改HelloDjango下的settings.py中的模板配置
-
修改settings.py中的模板配置中的静态资源配置
# 静态文件访问路由 STATIC_URL = '/static/' # 静态文件存储目录:根目录/static/ STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static'), ]
-
创建【根目录/static/img/】目录并放入一张wolf.jpg图片
-
创建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>
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、访问测试