Django:学习笔记(2)——创建第一个应用
Django:学习笔记(2)——创建第一个应用
创建应用
在 Django 中,每一个应用都是一个 Python 包,并且遵循着相同的约定。Django 自带一个工具,可以帮你生成应用的基础目录结构,这样你就能专心写代码,而不是创建目录了。
我们可以执行如下命令,来创建myweb应用。
python manager.py startapp myweb
执行结束后,python为我们的项目创建好了一个遵循约定的目录结构
注意:我们做一个区分,我们使用django-admin startproject创建后生成的目录为项目目录,应用目录是创建在项目目录内的,项目目录内同时包含了一个和项目同名的目录,我们叫项目源目录,后文不在赘述。
创建第一个视图
我们在目录中的views.py文件里,写入第一个视图,Hello World
from django.http import HttpResponse def index(request):
return HttpResponse("Hello World!")
视图有了,我们还需要一个URL来映射到它,我们需要在该目录下创建一个urls.py文件
from django.conf.urls import url,include from . import views urlpatterns = [
url('', views.index, name='index'),
]
下一步是要在根 URLconf 文件中指定我们创建的 myweb.urls
模块。在项目源目录urls.py
文件的 urlpatterns
列表里插入一个 include()
, 如下:
from django.conf.urls import url,include
from django.contrib import admin urlpatterns = [
url('web/',include('myweb.urls')),
url(r'^admin/', admin.site.urls)
]
现在我们已经可以通过访问/web路径,得到hello,world结果,效果如下图:
创建第一个模型
在 Django 里写一个数据库驱动的 Web 应用的第一步是定义模型 - 也就是数据库结构设计。
说明:
模型是真实数据的简单明确的描述。它包含了储存的数据所必要的字段和行为。Django 遵循 DRY Principle 。它的目标是你只需要定义数据模型,然后其它的杂七杂八代码你都不用关心,它们会自动从模型生成。
我们现在做一个用户登录的例子,首先我们需要定义用户信息模型。
# 定义一个用户信息
class User(models.Model):
username = models.CharField(max_length=16)
password = models.CharField(max_length=16)
gender = models.CharField()
mail = models.EmailField()
代码非常直白。模型被表示为 django.db.models.Model
类的子类。每个模型有一些类变量,它们都表示模型里的一个数据库字段。
每个字段都是 Field
类的实例 - 比如,字符字段被表示为 CharField
,日期时间字段被表示为 DateTimeField
。这将告诉 Django 每个字段要处理的数据类型。每个 Field
类实例变量的名字也是字段名,所以最好使用对机器友好的格式。你将会在 Python 代码里使用它们,而数据库会将它们作为列名。
注意:我们可以使用
ForeignKey
定义了一个关系。这将告诉 Django,每个Choice
对象都关联到一个Question
对象。Django 支持所有常用的数据库关系:多对一、多对多和一对一,我们将在后面文章补充这部分内容。
激活模型
上面我们创建一个用户模型,它给了 Django 很多信息,通过这些信息,Django 可以为这个应用创建数据库表结构(生成 CREATE TABLE
语句),同时创建可以与User对象进行交互的 Python 数据库 API。但在这之前,我们需要做一些操作。
把应用安装到项目
但是首先得把myweb 应用安装到我们的项目里。为了在我们的工程中包含这个应用,我们需要在项目源目录的setting.py中的 INSTALLED_APPS
中添加设置。因为 MyWebConfig
类写在文件 myweb/apps.py
中,所以它的点式路径是 'myweb.apps.MyWebConfig'
。如下图所示:
将模型同步到数据库
我们的模型创建好了以后,我们需要执行一些方法,告知django将我们写好的user模型同步到数据库中,即创建相应的表结构。
我们需要执行一次数据迁移,通过运行 makemigrations
命令,Django 会检测你对模型文件的修改(在这种情况下,你已经取得了新的),并且把修改的部分储存为一次 迁移,这一点很像Git,但是记住它只是记录一下你的修改操作而已。
django会在我们应用的migrations下创建迁移文件。
接着,我们再运行migrate命令,在数据库里创建新定义的模型的数据表。
python manage.py migrate
说明:我们也可以通过迁移文件,来查看会执行哪些SQL命令。
python manage.py sqlmigrate myweb 0001
总之,我们在修改模型后,需要执行两步操作来将新的模型同步到数据库中。
实践:实现用户注册
首先,我们还是要回顾一下这篇文章的内容,我们知道了如何创建一个视图以及设置URL映射、如何创建一个模型并且同步到数据库中,现在我们来实践一下实现用户注册。
在视图的处理中,我们可以做任何事情,并且返回任何我们需要反馈的信息。首先在想要获取到用户的请求信息,它们都被保存在request.GET和request.POST这两个字典中。
[文件:myweb/views.py]
def addUser(request):
# 创建用户对象
user = User()
# 获取请求数据
user.username = request.GET['username'];
user.password = request.GET['password'];
# 保存
user.save();
return HttpResponse('<p>用户添加成功</p>');
接着,我们在应用的urls.py中添加URL映射关系
[文件:myweb/urls.py]
urlpatterns = [
url("add",views.addUser)
]
按照GET方式,我们在访问时,需要在URL中拼接请求信息,如下
至此,我们的第一个实践内容结束,我们完成了一个获取用户请求信息,并调用模型内置方法将数据保存到数据库。
Django:学习笔记(2)——创建第一个应用的更多相关文章
- Django学习笔记---第一天
Django学习笔记 1.Django的安装 //如果不指定版本号,默认安装最新版 pip3 install django==1.11.8 关于Django的版本和python的版本依赖关系,请看下图 ...
- Django学习笔记(一)——安装,创建项目,配置
疯狂的暑假学习之 Django学习笔记(一) 教材 书<The Django Book> 视频:csvt Django视频 1.创建项目 django‐admin.py startpro ...
- Django学习笔记(五)—— 表单
疯狂的暑假学习之 Django学习笔记(五)-- 表单 參考:<The Django Book> 第7章 1. HttpRequest对象的信息 request.path ...
- Django 学习笔记(二)
Django 第一个 Hello World 项目 经过上一篇的安装,我们已经拥有了Django 框架 1.选择项目默认存放的地址 默认地址是C:\Users\Lee,也就是进入cmd控制台的地址,创 ...
- Django 学习笔记(七)数据库基本操作(增查改删)
一.前期准备工作,创建数据库以及数据表,详情点击<Django 学习笔记(六)MySQL配置> 1.创建一个项目 2.创建一个应用 3.更改settings.py 4.更改models.p ...
- Django学习笔记(4)——Django连接数据库
前言 在MVC或者MTV设计模式中,模型(M)代表对数据库的操作.那么如何操作数据库呢?本小节就认真学习一下.首先复习一下Django的整个实现流程 ,然后再实现一下使用数据库的整个流程,最后学习一下 ...
- Django学习笔记二
Django学习笔记二 模型类,字段,选项,查询,关联,聚合函数,管理器, 一 字段属性和选项 1.1 模型类属性命名限制 1)不能是python的保留关键字. 2)不允许使用连续的下划线,这是由dj ...
- Django学习笔记(13)——Django的用户认证(Auth)组件,视图层和QuerySet API
用户认证组件的学习 用户认证是通过取表单数据根数据库对应表存储的值做比对,比对成功就返回一个页面,不成功就重定向到登录页面.我们自己写的话当然也是可以的,只不过多写了几个视图,冗余代码多,当然我们也可 ...
- Django学习笔记(20)——BBS+Blog项目开发(4)Django如何使用Bootstrap
本文学习如何通过Django使用Bootstrap.其实在之前好几个Django项目中已经尝试使用过了Bootstrap,而且都留有学习记录,我已经大概有了一个大的框架,那么本文就从头再走一遍流程,其 ...
随机推荐
- elasticsearch插件三—— Marvel插件安装详解
2016年05月21日 22:58:13 阅读数:23058 一.Marvel插件介绍 Marvel插件:在簇中从每个节点汇集数据.这个插件必须每个节点都得安装. Marvel是Elasticsear ...
- 小程序WXML 使用小结
数据绑定 <view> {{message}} </view> // page.js Page({ data: { message: 'Hello MINA!' } }) 组件 ...
- sed awk文本处理教程
sed全名叫stream editor,流编辑器,用程序的方式来编辑文本,相当的hacker啊.sed基本上就是玩正则模式匹配,所以,玩sed的人,正则表达式一般都比较强. 把my字符串替换成Hao ...
- C语言 百炼成钢25
/* 题目61:编写一个名为removestring的函数,该函数用于从一个字符串中删除一定量的字符. 该函数接受三个参数: 第1参数代表源字符串 第2参数代表需要删除字符的起始位置(位置从0开始) ...
- Docker:通过Git部署
这是我翻译的国外博客,如需转载请注明出处和原文链接 我一直听说Docker是个很棒的新事物,但是我一直提不起兴趣,直到我遇到一个切实的问题: 如果通过Docker来部署 Scout ,这么做会轻松一些 ...
- 数据库I/O:CMP、Hibernate
★什么是“Persistence” 用过VMWare的朋友大概都知道当一个guest OS正在运行的时候点击“Suspend”将虚拟OS挂起,它会把整个虚拟内存的内容保存到磁盘上,譬如你为虚拟OS分配 ...
- 使用NPOI导入Excel注意日期格式和数字格式
//使用NPOI导入Excel public static DataTable importExcelToDataSetUsingNPOI(string FilePath, string fileNa ...
- UTF8转换为GB编码gb2312转换为utf-8
这个方法是用windows的字符集转换的,跟sybase 的unicode码表可能在某些符号上有差别,对于大部分字符来说,尤其是 汉字,应该不会有问题的,如果要求比较高的话,可以买sybase的 un ...
- Torch-RNN运行过程中的坑 [2](Lua的string sub函数,读取中文失败,乱码?)
0.踩坑背景 仍然是torch-rnn/LanguageModel.lua文件中的一些问题,仍然是这个狗血的LM:encode_string函数: function LM:encode_string( ...
- vc6项目-vc8项目 转换日志
此随笔参考了http://blog.163.com/feng_qihang/blog/static/7129199120093422722430/ 把VC6的项目转换成VS2005项目,经过VS200 ...