python收藏

Django入门指导

2015-08-15  本文已影响121人  秦汉邮侠

1,安装python包管理工具pip

在ubuntu环境下,我们通常apt-get来安装软件,当时pip是专门用来管理python包的工具,相对apt-get来说,安装与python有关的包更加方便,能够精确控制安装软件的版本,同时,当我们直接拿到别人的django工程时,如果有一些依赖的包,能够很快的使用pip解决依赖关系,pip之于python,npm之于node.js。
安装pip工具

 sudo apt-get install python-pip

2,安装django

通过第一步中pip工具,来安装django,有时我们下指定安装某个版本
sudo pip install Django==1.7.1
当然也可以直接通过apt-get来安装django
sudo apt-get install Django (不推荐)
当然也可以通过源码安装(耗时耗力,不推荐)
python命令行下检验是否安装成功

>>> import django
>>> django.VERSION
(1, 7, 1, 'final', 0)

3,新建django工程

django-admin startproject website 或者
django-admin.py startproject website
通过Linux源码安装或者pip安装django时,django-admin有可能用不了,推荐用django-admin.py
执行完上述命令,会在当前目录新建website工程,目录结构如下

fage:Server$ tree website
website
├── manage.py
└── website
    ├── __init__.py
    ├── settings.py
    ├── urls.py
    └── wsgi.py
1 directory, 5 files

新建一个website目录,还有website子目录,还有四个py文件
manage.py: ---------Django项目里面的命令行工具,用于跟项目的各种交互,通过它可以调用django shell和数据库
init.py: -------一个空文件让Python知道这个目录是一个Python包
settings.py -------- 包含了项目的默认设置,包括数据库信息,调试标志,时区,静态文件目录
urls.py ----- 负责把URL模式映射到应用程序,建立网址和视图函数之间的对应关系
wsgi.py ----- 负责和Nginx或者Apache交互用的,当使用django自带的web服务器时不用理会。
manage.py文件,我们会经常用到,但是我们基本不会改里面的内容,只是用来启动web服务,同步数据库等等
init.py基本不用关注
settings.py文件是我们经常需要修改的文件
urls.py也是我们经常需要修改的文件
wsgi.py当你把django部署在生产环境,用django自带的web服务器就不是很合适,这个时候我们需要部署Nginx或者Apache,此时需要设置wsgi.py

4,新建app

python manage.py startapp blog
fage:website$ tree
.
├── blog
│   ├── admin.py
│   ├── __init__.py
│   ├── migrations
│   │   └── __init__.py
│   ├── models.py
│   ├── tests.py
│   └── views.py
├── manage.py
└── website
    ├── __init__.py
    ├── __init__.pyc
    ├── settings.py
    ├── settings.pyc
    ├── urls.py
    └── wsgi.py

5,修改settings.py

添加app到 settings.py

INSTALLED_APPS = (
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'blog',
)

设置语言和时区

LANGUAGE_CODE = 'zh-CN'
TIME_ZONE = 'Asia/Shanghai'

6,修改urls.py

设置urls.py有两种方式

from django.conf.urls import patterns, include, url
from django.contrib import admin
urlpatterns = patterns('',
    # Examples:
    # url(r'^$', 'my0813.views.home', name='home'),
    # url(r'^blog/', include('blog.urls')),

    url(r'^admin/', include(admin.site.urls)),
    url(r'^blog/$', 'blog.views.blog_index', name='blog_index'),
) 
from django.conf.urls import patterns, include, url
from django.contrib import admin
urlpatterns = patterns('',
    # Examples:
    # url(r'^$', 'my0813_01.views.home', name='home'),
    # url(r'^blog/', include('blog.urls')),

    url(r'^admin/', include(admin.site.urls)),
    url(r'^blog/',  include('blog.urls')),#blog.urls的''不能省略
)

在blog目录新建urls.py,编辑urls.py

from django.conf.urls import patterns, url
urlpatterns = patterns('',
    # Examples:
    # url(r'^$', 'my0813_02.views.home', name='home'),
    # url(r'^blog/', include('blog.urls')),
    url(r'^$', 'blog.views.blog_index'),#$符号之后不要加/
)

7,编辑视图文件

编辑blog目录下的views.py文件

from django.shortcuts import render
from django.http import HttpResponse
# Create your views here.i
def blog_index(request):
    return HttpResponse("Hello, world.")

8,运行web服务

因为没有设置从html文件中获取数据, 就没有设置Templates目录和static目录,只是为了简单地显示一个hello world

python manage.py runserver 8000
python manage.py runserver 0.0.0.0:8000
上一篇下一篇

猜你喜欢

热点阅读