Django初探一

作者: meryin | 来源:发表于2017-10-19 15:33 被阅读12次

    前言

    这段时间在慕课网上学习了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。效果如下:

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

    相关文章

      网友评论

        本文标题:Django初探一

        本文链接:https://www.haomeiwen.com/subject/npvsuxtx.html