Django小白入门

创建第一个Django应用

安装准备

安装python

首先确定安装了pythoncmd下键入python,出现类似以下正确的提示符就是正确安装在这里插入图片描述

安装virtualenv和virualenvwrapper

virualenvwrapper是一个管理python 环境的工具,我们在开发python 应用的时候,可能会同时开发很多python应用,而每一个python项目所需要的环境(各种包)都不一样,分成多种环境来开发更清晰一点,并且想要删除一个项目的时候,可以连带环境一起删除。不会有多余的第三方包留在本地。这是一个可选项,但是非常必要的东西,建议安装。

安装

pip install virtualenvwrapper-win

然后为你的项目(当前目录)创建一个虚拟环境:

mkvirtualenv myproject

这时候在你当前目录会生成一个python目录文件,其实就是又一python而已。

选择这个环境下工作

workon myproject

这个时候命令行最左边有一个(myproject)字样,就是在这个环境下了,如下
在这里插入图片描述

安装Django

Django可以轻松在你的虚拟环境下使用pip安装

pip install django

输入命令确保安装成功,输入下面命令,得到的是版本号就OK了。

py -m django --version

编写第一个Django 应用----第一部分

创建项目


第一次使用Django,你需要一些初始化配置,你需要用一些自动生成的代码配置一个Django project一一即一个Django项目实例需要的设置项集合;包括数据库配置、Django配置和应用程序配置。

以下都是在myproject环境下,以下不在声明。

打开命令行,cd到一个你想放置你代码的目录,然后运行以下命令

django-admin startproject mysite

这行代码将会在当前目录创建一个mysite目录。

注解

你得避免使用 Python 或 Django 的内部保留字来命名你的项目。具体地说,你得避免使用像 django (会和 Django 自己产生冲突)或 test (会和 Python 的内置组件产生冲突)这样的名字。

我的代码该放在哪?

如果你曾经是原生 PHP 程序员(没有使用过现代框架),你可能会习惯于把代码放在 Web 服务器的文档根目录(诸如 /var/www)。当使用 Django 时不需要这样做。把所有 Python 代码放在 Web 服务器的根目录不是个好主意,因为这样会有风险。比如会提高人们在网站上看到你的代码的可能性。这不利于网站的安全。

把你的代码放在文档根目录 以外 的某些地方吧,比如 /home/mycode

让我们看看startproject创建了些什么:

mysite/
	manage.py
	mysite/
        __init__.py
        settings.py
        urls.py
        wsgi.py

这些目录和文件的用处是:

  • 最外层file:mysite/是你项目的容器,Django不关心它的名字,你可以将它重命名为任何你喜欢的名字。
  • manage.py:一个让你用各种方式管理Django项目的命令行工具。具体可查看相关文档
  • 里面一层的mysite/目录包含你的项目,它是一个纯python包。它的名字就是当你引用它内部任何东西时需要用到的 Python 包名。(比如mysit.urls
  • mysite/init.py:一个空文件,告诉Python这个目录应该被认为是一个Python包。
  • mysite/settings.py:Django项目的配置文件。
  • mysite/urls.py:Django项目的URL声明,就像你网站的“目录”。
  • mysite/wsgi.py:作为你的项目运行在WSGI兼容的Web服务器的入口

用于开发的简易服务器


让我们来确认一下你的 Django 项目是否真的创建成功了。如果你的当前目录不是外层的 mysite 目录的话,请切换到此目录,然后运行下面的命令:

py manage.py runserver

你应该会看到如下输出:

Performing system checks...
 
System check identified no issues (0 silenced).
 
You have unapplied migrations; your app may not work properly until they are applied.
Run 'python manage.py migrate' to apply them.
 
四月 06, 2019 - 15:50:53
Django version 2.2, using settings 'mysite.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CONTROL-C.

现在,服务器正在运行,浏览器访问 https://127.0.0.1:8000/。你将会看到一个“祝贺”页面,随着一只火箭发射,服务器已经运行了。ctrl+c退出

添加监听IP和监听端口

下面的代码就是监听全部IP和8080端口:

py manage.py runserver 0:8080

创建投票应用


现在你的开发环境——这个“项目” ——已经配置好了,你可以开始干活了。

在 Django 中,每一个应用都是一个 Python 包,并且遵循着相同的约定。Django 自带一个工具,可以帮你生成应用的基础目录结构,这样你就能专心写代码,而不是创建目录了。

项目 VS 应用

项目和应用有啥区别?应用是一个专门做某件事的网络应用程序——比如博客系统,或者公共记录的数据库,或者简单的投票程序。项目则是一个网站使用的配置和应用的集合。项目可以包含很多个应用。应用可以被很多个项目使用。

你的应用可以存放在任何 Python path 中定义的路径。在这个教程中,我们将在你的 manage.py 同级目录下创建投票应用。这样它就可以作为顶级模块导入,而不是 mysite 的子模块。

请确定你现在处于 manage.py 所在的目录下,然后运行这行命令来创建一个应用:

py manage.py startapp polls

这将会创建一个 polls 目录,它的目录结构大致如下:

polls/
    __init__.py
    admin.py
    apps.py
    migrations/
        __init__.py
    models.py
    tests.py
    views.py

这个目录结构包括了投票应用的全部内容。

编写第一个视图


让我们开始编写第一个视图吧。打开 polls/views.py,把下面这些 Python 代码输入进去:

polls/views.py

from django.http import HttpResponse
 
 
def index(request):
    return HttpResponse("Hello, world. You're at the polls index.")

这是 Django 中最简单的视图。如果想看见效果,我们需要将一个 URL 映射到它——这就是我们需要 URLconf 的原因了。

为了创建 URLconf,请在 polls 目录里新建一个 urls.py 文件。你的应用目录现在看起来应该是这样:

polls/
    __init__.py
    admin.py
    apps.py
    migrations/
        __init__.py
    models.py
    tests.py
    urls.py
    views.py

polls/urls.py 中,输入如下代码:

polls/urls.py

from django.urls import path
 
from . import views
 
urlpatterns = [
    path('', views.index, name='index'),
]

下一步是要在根 URLconf 文件中指定我们创建的 polls.urls 模块。在 mysite/urls.py 文件的 urlpatterns 列表里插入一个 include(), 如下:

mysite/urls.py

from django.contrib import admin
from django.urls import include, path
 
urlpatterns = [
    path('polls/', include('polls.urls')),
    path('admin/', admin.site.urls),
]

函数 include() 允许引用其它 URLconfs。每当 Django 遇到 :func:~django.urls.include 时,它会截断与此项匹配的 URL 的部分,并将剩余的字符串发送到 URLconf 以供进一步处理。

我们设计 include() 的理念是使其可以即插即用。因为投票应用有它自己的 URLconf( polls/urls.py ),他们能够被放在 “/polls/” , “/fun_polls/” ,"/content/polls/",或者其他任何路径下,这个应用都能够正常工作。

何时使用 include()

当包括其它 URL 模式时你应该总是使用 include()admin.site.urls 是唯一例外。

现在已经将索引视图连接到URLconf。使用以下命令查看效果

py manage.py runserver 8080

用你的浏览器访问 http://localhost:8080/polls/,你应该能够看见 “Hello, world. You’re at the polls index.” ,这是你在 index 视图中定义的。

函数 path() 具有四个参数,两个必须参数:routeview,两个可选参数:kwargsname。现在,是时候来研究这些参数的含义了。

path() 参数: route

route 是一个匹配 URL 的准则(类似正则表达式)。当 Django 响应一个请求时,它会从 urlpatterns 的第一项开始,按顺序依次匹配列表中的项,直到找到匹配的项。

这些准则不会匹配 GET 和 POST 参数或域名。例如,URLconf 在处理请求 https://www.example.com/myapp/ 时,它会尝试匹配 myapp/ 。处理请求 https://www.example.com/myapp/?page=3 时,也只会尝试匹配 myapp/

path() 参数: view

当 Django 找到了一个匹配的准则,就会调用这个特定的视图函数,并传入一个 HttpRequest 对象作为第一个参数,被“捕获”的参数以关键字参数的形式传入。稍后,我们会给出一个例子。

path() 参数: kwargs

任意个关键字参数可以作为一个字典传递给目标视图函数。本教程中不会使用这一特性。

path() 参数: name

为你的 URL 取名能使你在 Django 的任意地方唯一地引用它,尤其是在模板中。这个有用的特性允许你只改一个文件就能全局地修改某个 URL 模式。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值