Django入门

Deployment

Django 初级篇

虚拟环境 virtualenv

1
virtualenv venv -p python3

为project提供独立的python环境。pycharm默认开启的

  • 开启
1
source venv/bin/activate

开启后 命令行最左端有(venv)字样 代表虚拟环境开启

1
(venv) ➜  PlanA

注意开启后 所有操作都在venv环境下进行的

使用 python 而不是python3,pip而不是pip3

  • 关闭
1
deactivate
安装 Django
install django ```
1
2
3
4
5
6
7
8

就此环境搭建完毕

##### 开始构建项目(Project)

我的第一个项目`PlanA`

```django-admin startproject PlanA
1
2
3
4
5
6
7
8
9
10
PlanA/              <-- higher level folder
├── PlanA <-- django project folder ( `startproject` 命令创建的)
│ ├── PlanA
│ │ ├── __init__.py
│ │ ├── asgi.py
│ │ ├── settings.py
│ │ ├── urls.py
│ │ └── wsgi.py
│ └── manage.py
└── venv <-- virtual environment folder

这些目录和文件的用处是:(django 文档给出)

  • The outer mysite/ root directory is a container for your project. Its name doesn’t matter to Django; you can rename it to anything you like.
  • manage.py: 一个让你用各种方式管理 Django 项目的命令行工具。你可以阅读 django-admin and manage.py 获取所有 manage.py 的细节。
  • 里面一层的 mysite/ 目录包含你的项目,它是一个纯 Python 包。它的名字就是当你引用它内部任何东西时需要用到的 Python 包名。 (比如 mysite.urls).
  • mysite/__init__.py:一个空文件,告诉 Python 这个目录应该被认为是一个 Python 包。如果你是 Python 初学者,阅读官方文档中的 更多关于包的知识
  • mysite/settings.py:Django 项目的配置文件。如果你想知道这个文件是如何工作的,请查看 Django 配置 了解细节。
  • mysite/urls.py:Django 项目的 URL 声明,就像你网站的“目录”。阅读 URL调度器 文档来获取更多关于 URL 的内容。
  • mysite/asgi.py: An entry-point for ASGI-compatible web servers to serve your project. See How to deploy with ASGI for more details.
  • mysite/wsgi.py:作为你的项目的运行在 WSGI 兼容的Web服务器上的入口。阅读 如何使用 WSGI 进行部署 了解更多细节。

一个project可以包含很多个app

同一个app可以存在与多个project中

创建app
startapp boards ```
1
2
3
4
5
6
7
8
9
10
11
12

注意这次我们用的是`startapp`

.
├── __init__.py
├── admin.py
├── apps.py
├── migrations
│ └── __init__.py
├── models.py
├── tests.py
└── views.py

PlanA/ <– higher level folder
├── boards <– our new django app!
│ ├── init.py
│ ├── admin.py
│ ├── apps.py
│ ├── migrations
│ │ └── init.py
│ ├── models.py
│ ├── tests.py
│ └── views.py
├── PlanA <– django project folder ( startproject 命令创建的)
│ ├── PlanA
│ │ ├── init.py
│ │ ├── asgi.py
│ │ ├── settings.py
│ │ ├── urls.py
│ │ └── wsgi.py
│ └── manage.py
└── venv <– virtual environment folder

1
2
3
4
5
6



##### 本地运行服务 8000端口

``` python manage.py runserver
更换端口

默认情况下,runserver 命令会将服务器设置为监听本机内部 IP 的 8000 端口。

如果你想更换服务器的监听端口,请使用命令行参数。举个例子,下面的命令会使服务器监听 8080 端口:

1
$ python manage.py runserver 8080

如果你想要修改服务器监听的IP,在端口之前输入新的。比如,为了监听所有服务器的公开IP(这你运行 Vagrant 或想要向网络上的其它电脑展示你的成果时很有用),使用:

1
$ python manage.py runserver 0:8000

00.0.0.0 的简写。完整的关于开发服务器的文档可以在 :djamdin:runserver 参考文档中找到。

新版django 的路由 path与re_path
1
2
3
4
urlpatterns = [
path('polls/', include('polls.urls')),
path('admin/', admin.site.urls),
]

以前是url

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 模式。

当你了解了基本的请求和响应流程后,请阅读 教程的第 2 部分 开始使用数据库.

数据库迁移
manage.py makemigrations```
1
2

```python manage.py migrate

资料

https://tutorial.djangogirls.org/zh/ 一个gitbook,难度较低的教程,如果有基础不建议看

https://github.com/TwoWater/Python 国人写的教程,能够快速了解陌生的信息

https://docs.djangoproject.com/ 官方文档,更新较为即时,语言可选中文。

https://simpleisbetterthancomplex.com/series/beginners-guide/1.11/ 新人友善的博客,带你一步一步完成一个论坛类的project 17年写的有些东西需要更新。