看我多久能学会Django(一):环境准备

在之前的Django初体验的文章中,我们已经多Django有了初步的认识,了解了一些文件的作用。接下来,我们就真的进入Django的世界吧!
本系列参考自学堂教程:http://www.ziqiangxuetang.com/django/django-tutorial.html

我的操作系统为CentOS

安装Django

网上很多安装教程,我已安装最新版本的,查看安装版本:

>>> import django 
>>> django.VERSION
(1, 10, 5, 'final', 0)
>>> django.get_version()
'1.10.5'
>>> exit()
(None,)

安装 virtualenv

用 virtualenv 来管理多个开发环境,virtualenvwrapper 使得virtualenv变得更好用

# pip install virtualenv virtualenvwrapper

Requirement already satisfied: virtualenv in /usr/local/lib/python3.5/site-packages
Collecting virtualenvwrapper
  Downloading virtualenvwrapper-4.7.2.tar.gz (90kB)
    100% |████████████████████████████████| 92kB 417kB/s 
Collecting virtualenv-clone (from virtualenvwrapper)
  Downloading virtualenv-clone-0.2.6.tar.gz
Collecting stevedore (from virtualenvwrapper)
  Downloading stevedore-1.20.0-py2.py3-none-any.whl
Collecting pbr>=1.8 (from stevedore->virtualenvwrapper)
  Downloading pbr-2.0.0-py2.py3-none-any.whl (98kB)
    100% |████████████████████████████████| 102kB 624kB/s 
Requirement already satisfied: six>=1.9.0 in /usr/local/lib/python3.5/site-packages (from stevedore->virtualenvwrapper)
Installing collected packages: virtualenv-clone, pbr, stevedore, virtualenvwrapper
  Running setup.py install for virtualenv-clone ... done
  Running setup.py install for virtualenvwrapper ... done
Successfully installed pbr-2.0.0 stevedore-1.20.0 virtualenv-clone-0.2.6 virtualenvwrapper-4.7.2

然后修改初始化脚本~/.bash_profile或其它环境变量相关文件(如 .bashrc 或用 ZSH 之后的 .zshrc),添加以下语句

export WORKON_HOME=$HOME/.virtualenvs
export PROJECT_HOME=$HOME/workspace
source /usr/local/bin/virtualenvwrapper.sh

修改之后,立即生效:

source ~/.bash_profile

使用方法

mkvirtualenv  zjyd:创建运行环境zjyd
workon zjyd: 工作在 zqxt 环境 或 从其它环境切换到 zjyd 环境
deactivate: 退出终端环境

注意:我们在创建环境的时候可以添加参数--no-site-packages,这样,已经安装到系统Python环境中的所有第三方包都不会复制过来,这样,我们就得到了一个不带任何第三方包的“干净”的Python运行环境。

rmvirtualenv zjyd:删除运行环境zjyd
mkproject zjyd:创建mic项目和运行环境zjyd
mktmpenv:创建临时运行环境
lsvirtualenv: 列出可用的运行环境
lssitepackages: 列出当前环境安装了的包
创建的环境是独立的,互不干扰,无需sudo权限即可使用 pip 来进行包的管理。

基本命令

1,新建一个django project

django-admin startproject project-name

2,新建app

python manage.py startapp app-name

一般一个项目有多个app, 当然通用的app也可以在多个项目中使用。

3,同步数据库

python manage.py makemigrations
python manage.py migrate

这种方法可以创建表,当你在models.py中新增了类时,运行它就可以自动在数据库中创建表了,不用手动创建。

4,使用开发服务器
开发服务器,即开发时使用,一般修改代码后会自动重启,方便调试和开发,但是由于性能问题,建议只用来测试,不要用在生产环境。

python manage.py runserver
 
# 当提示端口被占用的时候,可以用其它端口:
python manage.py runserver 8001
python manage.py runserver 9999
(当然也可以kill掉占用端口的进程)
 
# 监听所有可用 ip (电脑可能有一个或多个内网ip,一个或多个外网ip,即有多个ip地址)
python manage.py runserver 0.0.0.0:8000
# 如果是外网或者局域网电脑上可以用其它电脑查看开发服务器
# 访问对应的 ip加端口,比如 http://172.16.20.2:8000

5,清空数据库

python manage.py flush 

此命令会询问是 yes 还是 no, 选择 yes 会把数据全部清空掉,只留下空表。

6,创建超级管理员

python manage.py createsuperuser
# 按照提示输入用户名和对应的密码就好了邮箱可以留空,用户名和密码必填
# 修改 用户密码可以用:
python manage.py changepassword username

7,导出数据 导入数据

python manage.py dumpdata appname > appname.json
python manage.py loaddata appname.json

8,Django 项目环境终端

python manage.py shell

如果你安装了 bpython 或 ipython 会自动用它们的界面,推荐安装 bpython。
这个命令和 直接运行 python 或 bpython 进入 shell 的区别是:你可以在这个 shell 里面调用当前项目的 models.py 中的 API,对于操作数据,还有一些小测试非常方便。

9,数据库命令行

python manage.py dbshell

Django 会自动进入在settings.py中设置的数据库,如果是 MySQL 或 postgreSQL,会要求输入数据库用户密码。

10,更多命令

终端上输入 python manage.py 可以看到详细的列表,在忘记子名称的时候特别有用。
[auth]
    changepassword
    createsuperuser

[django]
    check
    compilemessages
    createcachetable
    dbshell
    diffsettings
    dumpdata
    flush
    inspectdb
    loaddata
    makemessages
    makemigrations
    migrate
    sendtestemail
    shell
    showmigrations
    sqlflush
    sqlmigrate
    sqlsequencereset
    squashmigrations
    startapp
    startproject
    test
    testserver

[sessions]
    clearsessions

[staticfiles]
    collectstatic
    findstatic
    runserver
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容