django 安装
使用pip install django即可安装django 最新版本
查看安装的django版本
<pre>
import django
django.VERSION
输出(1, 10, 3, 'final', 0)
</pre>
创建一个django项目
django-admin startproject mysite
可以看到生成如下项目结构
manage.py是一个命令行工具用来与项目进行交互,类似django-admin,不需要编辑
mysite:
init.py是一个空文件,标记mysite是一个模块
setting.py项目的配置文件
urls.py项目的url模式配置文件
wsgi.py部署到正式服务器时使用
默认生成的setting.py文件会创建一个sqllite数据库以及一个django应用列表(admin、author、message...)需要使用migrate命令在数据库中去创建这些表
启动开发服务器
python3 manage.py runserver 默认启动127.0.0.1:8000端口只能本机访问
python3 manage.py runserver 8001 指定以127.0.0.1:8001端口访问
python3 manage.py runserver 0.0.0.0:8001 同一个网段中的机器都可以访问
项目设置setting.py
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(file)))
os.path.abspath(file)得到当前文件所在的绝对路径
os.path.dirname返回当前文件所在的目录,不包含当前文件或当前目录
这里的BASE_DIR为项目路径即E:/stud/mysite
SECRET_KEY为django生成的秘钥
DEBUG=True debug模式的开关
ALLOWED_HOSTS设置允许哪些域名可以访问
INSTALLED_APPS添加需要激活的应用
MIDDLEWARE 可执行的一些中间件
在MIDDLEWARE中加入'django.middleware.locale.LocaleMiddleware'可以设置admin后台显示为中文
ROOT_URLCONF指明定义的主url模式存放在哪个模块
DATABASES 数据库的相关配置
应用
一个项目可以有多个应用
创建一个应用<pre>python3 manage.py startapp blog</pre>
创建的blog应用目录结构如下
migrations这个目录用来跟踪model的变化并用来同步数据库
admin.py用来注册models,并将其加到django管理页面中
models.py定义数据模型层
views.py应用逻辑层,处理http请求
models
CharField相当与sql中的Varchar
SlugField只能包含字母、数字、下划线和连接符的字符串,通常用于存放urls
unique_for_date
title = meta.CharField(maxlength=30,unique_for_date='pub_date')
系统将不允许title和pub_date两个都相同的数据重复出现,unique_for_date的值必须为日期类型的字段
models中的class Meta包含元数据,ordering=('-publish')表示根据数据库查询出的结果按照publish的降序排序
str方法是当前对象的默认可读方法
models生成的表名为应用名_类名(小写),可以通过在Meta类下指定db_table的属性来指定表名
setting 中的INSTALLED_APPS列表用来激活创建的应用
创建和进行数据库的迁移
创建一个数据库迁移
python3 manage.py makemigrations blog
查看创建表的sql(不会执行)
python manage.py sqlmigrate blog 0001
运行一下命令来应用已存在的数据迁移
python manage.py migrate
如果使用migrate同步完数据库之后想要在models中创建的表中添加一列
在models中添加对应的字段
执行python3 manage.py makemigrations blog和python3 manage.py sqlmigrate blog 00X查看添加的对应字段的语句
之后进入数据库执行数据库添加字段的命令即可
ALTER TABLE table_name add col_name col_type default ..
在管理站点中添加模型
admin.site.register()
django reverse
django中的reverse函数的使用(可以避免在views中使用硬编码)
return reverse('blog:post_detail',
args=[self.publish.year,
self.publish.strftime('%m'),
self.publish.strftime('%d'),
self.slug])
url(r'^(?P<year>\d{4})/(?P<month>\d{2})/(?P<day>\d{2})/(?P<post>[-\w]+)/$',
views.post_detail,
name='post_detail')
</pre>
blog是app名,post_detail是url中配置的name名,args是url中所需的参数,用法可参考http://www.cnblogs.com/ajianbeyourself/p/4937951.html
django中的分页pagintor
django中自带一个分页类
基本语法实例
进入 python3 manage.py shell 下
<pre>
import os
from django.core.paginator import Paginator
objects = ['john','paul','george','ringo','lucy','meiry','checy','wind','flow','rain']
p = Paginator(objects,3) # 3条数据为一页,实例化分页对象
print p.count # 10 对象总共10个元素
print p.num_pages # 4 对象可分4页
print p.page_range # xrange(1, 5) 对象页的可迭代范围
page1 = p.page(1) # 取对象的第一分页对象
print page1.object_list # 第一分页对象的元素列表['john', 'paul', 'george']
print page1.number # 第一分页对象的当前页值 1
page2 = p.page(2) # 取对象的第二分页对象
print page2.object_list # 第二分页对象的元素列表 ['ringo', 'lucy', 'meiry']
print page2.number # 第二分页对象的当前页码值 2
print page1.has_previous() # 第一分页对象是否有前一页 False
print page1.has_other_pages() # 第一分页对象是否有其它页 True
print page2.has_previous() # 第二分页对象是否有前一页 True
print page2.has_next() # 第二分页对象是否有下一页 True
print page2.next_page_number() # 第二分页对象下一页码的值 3
print page2.previous_page_number() # 第二分页对象的上一页码值 1
print page2.start_index() # 第二分页对象的元素开始索引 4
print page2.end_index() # 第2分页对象的元素结束索引 6
</pre>
django models中的relate_name属性用于反向查询用,定义了一个外键时,通过外键字段查询时,此时的表名可以用relate_name的值代替,用法参考http://blog.csdn.net/lanyang123456/article/details/68962515
django models DateTimeField中的参数auto_now默认false,设置为true时用于每次保存最后修改时间,每次都会自动保存为更新的当前时间,auto_now_add默认false,设置为True时,保存的是首次创建时间以后修改时不会再更新。用法参照http://www.cnblogs.com/dreamer-fish/p/5556641.html