django官网
安装
- 源码安装
下载源码
然后 到django目录下 运行 pip install -e django/ - pip 安装 [推荐]
Install : pip install django(过程可能会比较慢)
创建项目和应用
新建项目
django-admin startproject projectname
项目目录
文件作用
- manage.py: 一个实用的命令行工具,可让你以各种方式与该 Django 项目进行交互。
- myblog: 项目的容器。
- myblog/init.py: 一个空文件,告诉 Python 该目录是一个 Python 包。
- myblog/settings.py: 该 Django 项目的设置/配置。
最核心 - myblog/urls.py: 该 Django 项目的 URL 声明; 一份由 Django 驱动的网站"目录",配置URL文件。
- myblog/wsgi.py: 一个 WSGI兼容的 Web 服务器的入口,以便运行你的项目。
不更改
Python Web Server Gateway Interface
Python服务器网关接口
Python应用与web服务器之间的接口
创建应用
进入manage.py同级目录
python manage.py startapp appname
添加应用名到settings.py中的INSTALLED_APPS 里
INSTALLED_APPS = [
...
'blog',
]
目录结构
文件作用
- admin.py: 当前应用的后台管理系统配置。
- migrations: 数据移植模块。
- migrations/init.py: 一个空文件。
- apps.py: 当前应用的配置。
最核心 - models.py: 数据模块,使用ORM框架。
- test.py: 自动化测试模块。
- views.py:执行响应的代码所在模块,代码逻辑处理的主要地点,主要代码编辑区域。
创建第一个页面(响应)
- 编辑blog.views
每个响应对应一个函数,函数必须返回一个响应
函数必须存在一个参数,一般设定为request
每个响应对应一个url
from django.http import HttpResponse
def index(request):
return HttpResponse('nihao shijie!')
- 编辑urls.py
每个URL都以url的形式写出来
url函数放在urlpatterns列表中
url函数三个参数;URL(正则),对应方法,名称
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^index/', bv.index),#新增
]
- 配置url方法二
编辑urls.py
from django.conf.urls import url,include
from django.contrib import admin
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^blog/', include('blog.urls')),#更改为^blog,地址以blog开头
]
在app目录下新建urls.py文件
from django.conf.urls import url
from .import views
urlpatterns = [
url(r'^index/$', views.index),#正则表达式(RE)可为空(r'^$'),也可为固定的一个地址,注意index后的'/'
]
在浏览器地址栏中输入http://127.0.0.1:8000/blog/index/ 即可
- 注意事项
根urls.py针对app配置的url名称,是该app所有url的总路径
配置url时注意正则表达式结尾符号$和/
开发一个template(界面)
template
是一个HTML文件
使用了Django模板语言(Django Template Language,DTL)(引擎)
可以使用第三方模板(如Jinja2)
步骤
- 在app根目录下创建名为Templates的目录
- 在该目录下创建HTML界面
- 在views.py中返回render()
def index(request):
return render(request, 'index.html')
DTL初步使用
render()函数中支持一个dict类型参数
该字典是后台传递到模板的参数,键为参数名
return render(request, 'index.html',{'hello':'Happy new year!'})
在模板中使用{{参数名}}来使用
<body>
<h1>{{hello}}</h1>
</body>
此处有坑
此时再新建一个app,此目录下Templates中的html界面命名与之前app一样,则django会按照installed_app中的顺序查找,以至于会忽略掉新建的template
解决办法:将app的Templates目录下创建与app同名的目录
将html文件放入该目录中,同时更改views.py文件中的render()第二个参数
Models
概念
通常,一个Model对应数据库的一张数据表
Django中Models以类的形式表现
它包含了一些基本字段以及数据的一些行为
实现了ORM(对象关系映射)
实现了对象和数据库之间的映射
隐藏了数据访问细节(封装了数据库的操作,不用写SQL语句)
编写Models
步骤
- 在应用根目录下创建models.py,并引入models模块
- 创建类,继承models.Model,该类即使一张数据表
- 在类中创建字段
字段即类中的属性(变量)
title = models.CharField(max_length = 32,default = 'title')
content = models.TextField(null = True)
https://docs.djangoproject.com/en/1.10/ref/models/fields/
生成数据表
步骤
- 在命令行中进入manage.py同级目录
- 执行 python manage.py makemigrations app名(可选)
- 再执行 python manage.py migrate
查看 - Django会自动在app/migreations/目录下生成移植文件
- 执行python manage.py sqlmigrate appname 文件id 查看sql语句
CREATE TABLE "blog_article" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, "title" varchar(32) NOT NULL, "content" text NULL);
页面呈现数据
- 后台步骤
修改views.py
from. import models
...
article = models.Article.objects.get(pk=1)
return render(request, 'index.html', {'article': article})
- 前端步骤
模板可直接使用对象以及对象的"."操作
<body>
<h1>{{article.title}}</h1>
<h3>{{article.content}}</h3>
</body>
Admin
简介
- 自带的自动化数据管理界面
- 被授权的用户可直接在admin中管理数据库
- 许多针对Admin的定制功能
配置
- 创建用户
python manage.py createsuperuser 创建超级用户 - 修改admin界面为中文
修改settings.py 中LANGUAGE_CODE = 'zh_Hans'
配置应用(增加数据库管理)
- 在应用下admin.py中引入自身的models模块(或里边的模型类)
from models import Article
- 编辑 admin.py:admin.site.register(models.Article)
admin.site.register(Article)
修改数据默认显示名称
- 在Article下添加一个方法
def __unicode__(self):(python 2.X)
return self.title
or
def __str__(self):(python 3.X)
return self.title
完善博客
博客页面设计
页面概要
- 博客主页面
- 博客文章内容页面
- 博客撰写页面
博客主页面
主页面内容
- 文章标题列表,超链接
- 发表博客按钮(超链接)
列表编写思路
- 读取数据库中所有文章对象
- 将文章对象们打包成列表,传递到前端
- 前端页面把文章以标题超链接的形式逐个给出
实现思路
模板For循环
{% for xx in xxs %}
HTML语句
{%endfor %}
具体实现
后台代码,修改views.py
def index(request):
articles = models.Article.objects.all()
return render(request, 'index.html', {'articles': articles})
前端代码,修改index.html
博客文章界面
编写思路
- 标题
- 文章内容
- 修改文章按钮(超链接)
具体实现
- 在views.py中增加一个响应
def article_page(request, article_id):
article = models.Article.objects.get(pk=article_id)
return render(request,'blog/article_page.html',{'article':article})
- 配置app目录下的urls.py文件,正则中的组名必须和参数名一致
url(r'^article/(?P<article_id>[0-9]+)$', views.article_page),
- 编写界面,新建article_page.html文件
<body>
<h1>{{article.title}}</h1>
<br/>
<h3>
{{article.content}}
</h3>
<br/><br/>
<a href="">Edit</a>
</body>
- 浏览器输入 http://127.0.0.1:8000/blog/article/1 验证
超链接配置
超链接目标地址
href后面是目标地址
template中可以用"{% url 'app_name:url_name' param %}"
其中app_name和url_name都在url中配置
再配URL
- 根urls,写在include()的第二个参数位置,namespace = 'blog'
url(r'^blog/', include('blog.urls', namespace='blog')),
- 应用下则写在url()的第三个参数位置,name = 'article'
url(r'^article/(?P<article_id>[0-9]+)$',
views.article_page, name='article_page'),
主要取决于是否使用include引用了另外一个url配置文件
- 修改index.html
<a href="{% url 'blog:article_page' article.id%}">{{article.title}}</a>
博客撰写页面
页面内容
- 标题编辑栏
- 文章内容编辑区域
- 提交按钮
实现
- 新建页面
<form action="" method="post">
{% csrf_token %}<!--post表单都需要添加这一句,避免403错误-->
<label>文章标题
<input type="text" name="title"/>
</label>
<br/>
<label>文章内容
<input type="text" name="content"/>
</label>
<br/>
<input type="submit" value = "提交"/>
<br/>
</form>
- 编辑响应函数
使用request.POST['参数名']获取表单数据,使用models.Article.objects.create(title, content)创建对象,写入数据库,然后返回主页
def edit_action(request):
title = request.POST.get('title', 'TITLE')
content = request.POST.get('content', 'CONTENT')
models.Article.objects.create(title=title, content=content)
articles = models.Article.objects.all()
return render(request, 'blog/index.html', {'articles': articles})
博客修改页面
思路
- 新文章为空。修改文章有内容
- 修改文章页面有文章对象
- 文章的ID
实现 - 修改响应函数
def edit_page(request, article_id):
if str(article_id) == '0':#判断是编辑还是新建
return render(request, 'blog/edit_page.html')
else:
article = models.Article.objects.get(pk=article_id)
return render(request, 'blog/edit_page.html', {'article': article})
def edit_action(request):
title = request.POST.get('title', 'TITLE')
content = request.POST.get('content', 'CONTENT')
article_id = request.POST.get('article_id', '0')
if article_id == '0':
models.Article.objects.create(title=title, content=content)
articles = models.Article.objects.all()
return render(request, 'blog/index.html', {'articles': articles})
article = models.Article.objects.get(pk=article_id)
'''
修改数据库
'''
article.title = title
article.content = content
article.save()
return render(request, 'blog/article_page.html', {'article': article})
- 修改 blog/urls.py
url(r'^edit/(?P<article_id>[0-9]+)$', views.edit_page, name='edit_page'),
- 修改前端文件
index.html
<a href="{% url 'blog:edit_page' 0 %}">新文章</a>
edit_page.html
{% if article %}
<input type="hidden" name="article_id" value="{{article.id}}">
<label>文章标题
<input type="text" name="title" value="{{article.title}}" />
</label>
<br/>
<label>文章内容
<input type="text" name="content" value="{{article.content}}" />
</label>
<br/>
<input type="submit" value="提交" />
<br/> {% else %}
<input type="hidden" name="article_id" value="0">
<label>文章标题
<input type="text" name="title" />
</label>
<br/>
<label>文章内容
<input type="text" name="content" />
</label>
<br/>
<input type="submit" value="提交" />
<br/>
{% endif %}
django trick
Templates过滤器
简介
写在模板中,属于django模板语言
可以修改模板的变量,从而显示不同的内容
使用
{{ value|filter }}
例子:{{ list_nums | length }} 显示长度
<input type="hidden" name="article_id" value="{{article.id | default:'0'}}">
省去了if else的重复代码
官方文档
django shell
简介
一个python的交互式命令行程序
优点:自动引入了项目环境,可以与项目交互
使用
python manage.py shell
例子:
获得数据库
from blog.models import Article
Article.objects.all()
作用
- 调试
- 测试未知的方法
Admin增强
显示数据库中的数据更多的列
修改admin.py
- 创建admin配置类
class ArticleAdmin(admin.ModelAdmin):
pass
- 注册配置类
admin.site.register(Article,ArticleAdmin)
- 显示其他字段
class ArticleAdmin(admin.ModelAdmin):
list_display = ('title','content')
过滤器
与django模板中的不同
class ArticleAdmin(admin.ModelAdmin):
list_display = ('title','content','pub_time')
list_filter = ('pub_time',)
在之前先加上时间的属性
官方文档