Django基础

作者: 圣世修罗 | 来源:发表于2016-12-28 22:35 被阅读289次

    Django 创建第一个项目

    使用 django-admin.py 来创建 HelloWorld 项目:

    django-admin.py startproject HelloWorld
    

    创建完成后我们可以查看下项目的目录结构:

    [root@solar HelloWorld]# tree
    .
    |-- HelloWorld
    | |-- __init__.py
    | |-- settings.py
    | |-- urls.py
    | `-- wsgi.py
    `-- manage.py
    

    目录说明:

    • HelloWorld: 项目的容器。
    • manage.py: 一个实用的命令行工具,可让你以各种方式与该 Django 项目进行交互
    • HelloWorld/init.py:一个空文件,告诉 Python 该目录是一个 Python 包。
    • HelloWorld/settings.py:该 Django 项目的设置/配置.
    • HelloWorld/urls.py:该 Django 项目的 URL 声明; 一份由 Django 驱动的网站"目录"。
    • HelloWorld/wsgi.py: 一个 WSGI 兼容的 Web 服务器的入口,以便运行你的项目。
      接下来我们进入 HelloWorld 目录输入以下命令,启动服务器:
    python manage.py runserver 0.0.0.0:8000
    

    视图和 URL 配置

    在先前创建的 HelloWorld 目录下的 HelloWorld 目录新建一个 view.py 文件,并输入代码:

    from django.http import HttpResponse
    def hello(request): 
      return HttpResponse("Hello world ! ")
    

    接着,绑定 URL 与视图函数。打开 urls.py 文件,删除原来代码,将以下代码复制粘贴到 urls.py 文件中:

    from django.conf.urls import *
    from HelloWorld.view import hello
    urlpatterns = [url(r'^hello/$', hello),]
    

    Django 模板

    上面我们使用 django.http.HttpResponse() 来输出"Hello World!"。该方式将数据与视图混合在一起,不符合Django的MVC思想。
    在 HelloWorld 目录底下创建 templates 目录(与manage.py同级)并建立 hello.html文件:

    <h1>{{ hello }}</h1>
    

    接下来我们需要向Django说明模板文件的路径,修改HelloWorld/settings.py,修改 TEMPLATES 中的 DIRS 为 [BASE_DIR+"/templates",]

    修改 view.py,增加一个新的对象,用于向模板提交数据:

    from django.shortcuts import render
    def hello(request): 
      context = {} 
      context['hello'] = 'Hello World!' 
      return render(request, 'hello.html', context)
    

    这里使用render来替代之前使用的HttpResponse。render还使用了一个字典context作为参数。
    context 字典中元素的键值 "hello" 对应了模板中的变量 "{{ hello }}"。

    数据库配置

    在项目的 settings.py 文件中找到 DATABASES 配置项

    DATABASES = {
      'default': { 
        'ENGINE': 'django.db.backends.mysql', # 或者使用 mysql.connector.django 
        'NAME': 'test', 
        'USER': 'test', 
        'PASSWORD': 'test123', 
        'HOST':'localhost', 
        'PORT':'3306', 
      }
    }
    

    定义模型

    创建 APP

    Django规定,如果要使用模型,必须要创建一个app。我们使用以下命令创建一个 TestModel 的 app:

    python manage.py startapp TestModel
    

    修改 TestModel/models.py:

    # models.py
    from django.db import models
    class Test(models.Model): 
      name = models.CharField(max_length=20)
    

    以上的类名代表了数据库表名,且继承了models.Model,类里面的字段代表数据表中的字段(name),数据类型则由CharField(相当于varchar)、DateField(相当于datetime), max_length 参数限定长度。

    接下来在settings.py中找到INSTALLED_APPS这一项,如下:

    'TestModel', # 添加此项
    

    在命令行中运行python manage.py syncdb,看到几行"Creating table…"的字样,你的数据表就创建好了。表名组成结构为:app名_类名(如:TestModel_test)。

    数据库操作

    接下来我们在 HelloWorld 目录中添加 testdb.py 文件,并修改urls.py:

    from django.conf.urls import *
    from HelloWorld.view import hello
    from HelloWorld.testdb import testdb
    urlpatterns = patterns("", ('^hello/$', hello), ('^testdb/$', testdb),)
    

    添加数据

    添加数据需要先创建对象,然后再执行 save 函数,相当于SQL中的INSERT:

    from django.http import HttpResponse
    
    from TestModel.models import Test
    

    数据库操作

    def testdb(request):
      test1 = Test(name='aaa')
      test1.save()
      return HttpResponse("<p>数据添加成功!</p>")
    

    访问http://xxxx:8000/testdb/ 就可以看到数据添加成功的提示。

    获取数据

    #通过objects模型管理器的all()获得所有数据行,相当于sql中的select * from
    list = Test.objects.all()
    testx1 = Test.objects.get(id=1)
    #限制返回的数据 相当于SQL中的OFFSET 0 LIMIT 2;
    Test.obiects.order_by('name')[0:2]
    #排序
    Test.objects.order_by("id")
    #上面的方法可以连锁使用
    Test.obiects.filter(name=' ').order_by(id)
    

    更新数据

    save() 或 update():

    test1 = Test.objects.get(id=1)
    test1.name = 'xxx'
    test1.save()
    
    #另一种方式
    Test.objects.filter(id=1).update(name='new name')
    

    删除数据

    Test.objects.filter(id=1).delete()
    

    HTTP请求

    Post

    在tmplate 创建 post.html:

    <form action="/search-post/" method="post">
      {% csrf_token %}
      <input type="text" name="q">
      <input type="submit" value="Submit">
    </form>
    <p>{{ rlt }}</p>
    

    在模板的末尾,我们增加一个rlt记号,为表格处理结果预留位置。
    表格后面还有一个{% csrf_token %}的标签。csrf全称是Cross Site Request Forgery。这是Django提供的防止伪装提交请求的功能。POST方法提交的表格,必须有此标签。
    在HelloWorld目录下新建 search2.py 文件并使用 search_post 函数来处理 POST 请求:

    # -*- coding: utf-8 -*-
    
    from django.shortcuts import render
    from django.core.context_processors import csrf
    
    # 接收POST请求数据
    def search_post(request):
        ctx ={}
        ctx.update(csrf(request))
        if request.POST:
            ctx['rlt'] = request.POST['q']
        return render(request, "post.html", ctx)
    

    urls.py 规则修改为如下形式:

    from django.conf.urls import *
    from HelloWorld.view import hello
    from HelloWorld.testdb import testdb
    from HelloWorld import search
    from HelloWorld import search2
    
    urlpatterns = patterns("",
        ('^hello/$', hello),
        ('^testdb/$', testdb),
        (r'^search-form/$', search.search_form),
        (r'^search/$', search.search),
        (r'^search-post/$', search2.search_post),
    )
    

    Request 对象

    每个view函数的第一个参数是一个HttpRequest对象

    Django Admin 管理工具

    创建超级用户

    python manage.py createsuperuser
    

    为了让admin界面管理某个数据模型,我们需要先注册该数据模型到admin。比如,我们之前在 TestModel 中已经创建了模型 Test 。修改 TestModel/admin.py:

    from django.contrib import admin
    from TestModel.models import Test
    
    # Register your models here.
    admin.site.register(Test)
    

    更多细节参见:
    http://www.runoob.com/django/django-tutorial.html

    相关文章

      网友评论

        本文标题:Django基础

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