女程序猿程序员

Django初探一

2017-10-19  本文已影响12人  meryin

前言

这段时间在慕课网上学习了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 render
from django.http import HttpResponse

def index(request):
    return HttpResponse('hello world')

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

from django.conf.urls import url
from django.contrib import admin
from myblog import views

urlpatterns = [
    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,include
from django.contrib import admin


urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^myblog/', include('myblog.urls')),
]

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

from django.conf.urls import url
from . import views

urlpatterns = [

    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 render
from django.http import HttpResponse

def 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 models

class 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 render
from django.http import HttpResponse
from . import models

def 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中显示数据:

<body>
    <h1>{{param1}}</h1>
    {% for artical in articals %}
        <a href="">{{artical.title}}</a>
    {% endfor %}
</body>

五、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 admin
from . import models

class 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。效果如下:

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

上一篇下一篇

猜你喜欢

热点阅读