博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Django初探一
阅读量:5811 次
发布时间:2019-06-18

本文共 4674 字,大约阅读时间需要 15 分钟。

小白的Django学习笔记。本人随便写写,本人用的mac+Python3.6。

一、环境搭建

1. 安装Django

由于我的运行环境是mac+python3.6,所以我用的是Django1.11版本:

pip install Django==1.11复制代码

如下:

2. 创建项目

本人创建的项目名称叫:blogDemo,所以代码如下:

django-admin startproject blogDemo复制代码

3. 创建应用

然后进入和manage.py同级的项目文件夹,用命令创建应用myblog:

python manage.py startapp myblog复制代码

启动服务器:

python manage.py runserver复制代码

启动服务器后,获取到的地址,就是本项目根地址: Django version 1.11, using settings 'blogDemo.settings' Starting development server at http://127.0.0.1:8000/ Quit the server with CONTROL-C. 改变端口:

python manage.py runserver 9999(端口号)复制代码

二、hello world

1. 项目结构介绍

项目文件下的settings.py是项目的配置文件,包括是否debug模式,APP注册,语言设置等等。我把项目的根地址改成localhost,便于访问。在setting.py中ALLOWED_HOSTS = ['localhost']。urls.py是项目的url文件,所有的url都要在urlpatterns注册。其他的文件暂时不管。 应用文件下的的admin.py是后台管理系统的管理文件。models.py相当于MVC中的M文件,一个类对应一张表,Django直接用类来操作数据库。views.py是主要响应文件,每个响应对应一个函数,函数必须返回一个响应,每个响应函数对应一个url。其他的文件暂时不管,一时记不住不管,往下写代码就行。

2. 开始写代码

所以的应用必须在settings.py中注册:

INSTALLED_APPS = [    'django.contrib.admin',    'django.contrib.auth',    'django.contrib.contenttypes',    'django.contrib.sessions',    'django.contrib.messages',    'django.contrib.staticfiles',    'myblog']复制代码

然后在views.py中写页面数据代码:

from django.shortcuts import renderfrom django.http import HttpResponsedef index(request):	return HttpResponse('hello world')复制代码

所有的页面都要在urls.py中注册:

from django.conf.urls import urlfrom django.contrib import adminfrom myblog import viewsurlpatterns = [    url(r'^admin/', admin.site.urls),    url(r'^index/', views.index),]复制代码

然后打开网址localhost:8000/index效果就出来啦,当然前提得是你启动了服务器python manage.py runserver。

3. url注册

由于项目的复杂性,所有应用的url都在urls.py中注册,容易重名,不易读,也不便管理,所以在应用myblog文件夹下新建一个urls.py用于管理本应用的url。项目的urls.py文件代码如下:

from django.conf.urls import url,includefrom django.contrib import adminurlpatterns = [    url(r'^admin/', admin.site.urls),    url(r'^myblog/', include('myblog.urls')),]复制代码

然后在应用文件夹下的urls.py中代码如下:

from django.conf.urls import urlfrom . import viewsurlpatterns = [    url(r'^index/$', views.index),]复制代码

然后打开网址**localhost:8000/myblog/index/**测试。

三、templates

1. 创建template文件:index.html

由于Django是由settings.py中的INSTALLED_APPS应用添加顺序来查找templates,所以不同应用下的html文件重名后会发生冲突。解决方案是,在应用目录的templates下,创建与应用同名的文件夹,把html文件放在此文件夹里。

2.显示index.html

在views.py中返回此界面:

from django.shortcuts import renderfrom django.http import HttpResponsedef index(request):	return render(request,'myblog/index.html',{
'param1':'hello 你好'})复制代码

在index.html中显示参数param1的数据:<h1>{

{param1}}}</h1>,参数的数据显示用{
{}}括起来。更多资料点。

四、models

1. 在APP目录中的models.py中创建类,继承models.Model。

from django.db import modelsclass Artical(models.Model):	title = models.CharField(max_length=32)	content = models.TextField(max_length=100)复制代码

更多变量的属性。

2. 生成数据表

先输入命令:python manage.py makemigrations然后再输入命令python manage.py migrate。 完成数据迁移后应用目录中会出现migrations的文件夹,里面有0001_initial.py文件,这个文件就是Artical模型的初始化文件,你可以在终端用命令python manage.py sqlmigrate myblog 0001查看sql语句。

3 . 插入并显示数据

python manage.py migrate 过后,文件中多了一个db.sqlite3的数据库。除了用打开数据库认为添加数据,还可以代码添加,详细资料点。在models.py中代码如下:

class ArticalManager(models.Manager):    def create_artical(self,title,content):        artical =self.create(title = title,content = content)        return artical	class Artical(models.Model):	title = models.CharField(max_length=32)	content = models.TextField(max_length=100)	objects = ArticalManager()复制代码

然后views.py中实现数据响应:

from django.shortcuts import renderfrom django.http import HttpResponsefrom . import modelsdef index(request):	articals = models.Artical.objects.all()  #获取全部数据    #artical = models.Artical.objects.get(pk=1)  获取第一行数据	if len(articals) == 0:		artical = models.Artical.objects.create_artical("这是标题","这是内容")		artical.save()		articals = models.Artical.objects.all()	return render(request,'myblog/index.html',{
'param1':'我的首页','articals':articals})复制代码

在index.html中显示数据:

	

{
{param1}}

{% for artical in articals %} {
{artical.title}}
{% endfor %}复制代码

五、admin操作

1. 创建用户

输入命令python manage.py createsuperuser创建超级用户,然后登陆后台管理系统localhost:8000/admin/。就看到以下界面:

为什么没有我的Artical表呢,因为Artical没有在admin注册,所以admin并不知道它。在admin.py中写下代码:
admin.site.register(models.Artical)然后首页就有了Artical表,点进Artical详情后显示的是Artical object。如果想要显示标题和其他字段,代码如下:

from django.contrib import adminfrom . import modelsclass ArticalAdmin(admin.ModelAdmin):	list_display = ('title','content')admin.site.register(models.Artical,ArticalAdmin)复制代码

然后效果如下:

2. 改变语言

后台管理系统一般默认为英语,想中文显示,在settings.py中把LANGUAGE_CODE 改成 'zh_Hans' 就好啦。

3.

比如你在Artical的后台管理界面,只想看某一天的记录,那么我们在models.py中添加一个字段pub_time = models.DateField(null=True),然后在admin.py中的ArticalAdmin类中添加list_filter = ('pub_time',),最后要进行数据迁移python manage.py makemigrationspython manage.py migrate。效果如下:

最后,还有好多,懒得写了。

转载于:https://juejin.im/post/5a31d71251882531d8286c34

你可能感兴趣的文章