frist Django app — 一、 创建工程

缘起

既然python都学了,学习python的时候感觉是相见恨晚,一种新的编程语言带给我一种新的思考问题的方式,为了巩固学过的东西并进一步学习python,就想学学Django,看看会不会带给我关于web新的东西。把自己学习过程记录在这里,发现每次写博客都是对学习过的东西的一次整理和提升。

新建一个project

startproject

python和Django的安装不再详述,我的环境python2.7,Django1.9.7 。

django-admin startproject mysite

上面这句话创建了一个project名称位mysite,这个名称是可以修改的,目录结构如下:

.
├── manage.py
└── mysite
    ├── __init__.py
    ├── settings.py
    ├── urls.py
    └── wsgi.py

对于上面几个文件的介绍:

manage.py:与Django进行交互的命令行工具,比如后面根据model生成数据库表结构、供开发使用的server等都是使用该工具,在manage.py的同级目录使用python manage.py 可以看到可以使用的命令列表。

mysite:这个才是工程的包名。

__init__.py:表明mysite是一个包。

setting.py:Django的配置文件,包括工程的app配置、数据库配置、语言配置等。

urls.py:Django的dispatcher,根据不同的url映射到不同的视图。

wsgi.py:WSGI是web server gateway interface,这个文件是使project符合这种协议的入口点(entry-point)

runserver

python manage.py runserver

在manage.py的同级目录下运行这个命令就可以看到以下内容:

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.

July 10, 2016 - 09:20:57
Django version 1.9.7, using settings ‘mysite.settings‘
Starting development server at http://127.0.0.1:8000/
Quit the server with CONTROL-C.

说明我们成功创建了一个project,在浏览器中输入 http://127.0.0.1:8000/,看到以下画面表示成功:

Django自带了一个开发服务器,便于开发使用(Django官方强调不能用作生产环境),默认端口号是8000,如果想运行在别的端口号,以下面的方式运行即可,比如:8080

python manage.py runserver 8080# 如果想在局域网内其他电脑上访问你的站点python manage.py runserver 0.0.0.0:8080

按Ctrl C停止服务器。

新建一个app

一个project可以又多个app,一个app可以同时属于多个project。通过以下命令创建一个app(在project目录下)

django-admin startapp polls

创建app后的目录结构,因为Django会自动创建一系列文件,我们需要明白每个为文件的作用

.
├── manage.py
├── mysite
│   ├── __init__.py
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
└── polls
    ├── admin.py
    ├── apps.py
    ├── __init__.py
    ├── migrations
    │   └── __init__.py
    ├── models.py
    ├── tests.py
    └── views.py

polls:app的根目录

admin.py:Django自带了一个管理界面,这个文件可以注册model在界面中管理

__init__.py:表明polls也是一个包

migrations:用来初始化数据库,在执行python manage.py makemigrations 的时候会自动生成一个文件在这里

__init__.py:表明migrations也是一个包

models.py:在这个文件里面定义model类

tests.py:写测试代码

views.py:视图,Django映射urls.py里面的url的时候,在views.py里面查找对应的处理方法

添加view

编辑views.py文件

from django.shortcuts import render
from django.http import HttpResponse

# Create your views here.
def index(request):
    return HttpResponse("hello world")

添加映射

在polls目录下新建urls.py文件

from django.conf.urls import url
from . import views

urlpatterns = {
    url(r‘^$‘, views.index, name = ‘index‘),
}

将polls的urls.py告诉django,添加到mysite/urls.py

from django.conf.urls import url, include
from django.contrib import admin

urlpatterns = [
    url(r‘^admin/‘, admin.site.urls),
    url(r‘^polls/‘, include(‘polls.urls‘)),
]

将我们polls包下面的urls.py include进去。大家注意到了polls/urls.py相当于是mysite/urls.py下面的一个子文件,两者 的写法相似,url的第一个参数是一个正则表达式,第二个参数就是映射到的视图或者包含的类,注意到原来有一个url(r‘^admin/‘, admin.site.urls),这是Django管理界面的配置,还有就是我们写的正则表达式是以polls/开始的url,也就是所有以该前缀开始的url都会被分发到polls/urls里面进一步寻找对应的视图。

接下运行server,访问http://127.0.0.1:8000/polls/就可以看到以下内容——也就是我们在views.py里面写的内容

hello world

总结

其实主要就是通过django提供的一些命令我们基本上就完成了一个简单的hello world,说到了Django的目录结构,简单涉及了一些view和url的写法。



代码位置

http://pan.baidu.com/s/1o84GjVk

时间: 2024-10-28 19:49:43

frist Django app — 一、 创建工程的相关文章

方便Django命令行创建工程及应用

1 ''' 2 由于Django中命令行创建工程 3 2017-8-4 by:羽凡 4 ''' 5 import os 6 import time 7 #创建工程的名字 8 project_name = input('Project:') 9 #创建应用的名字 10 app_name = input('App:') 11 #构造命令 12 Porder = 'django-admin startproject '+str(project_name) 13 Aorder = 'python man

frist Django app — 五、Test

Test——很重要但是没有被重视起来的一个环节,至少是我自己,其实自己之前在做java web的时候就去尝试过怎么做REST接口的测试,一直没有找到一种合适方式,而且因为时间紧没有进一步深究,但是造成的后果每次做了修改之后都测试不充分,引起新的问题,所以这次对于python正好看看Django的单元测试. 用的是单独的数据库,数据库是干净的(暂未有数据库,test所有操作都是从零开始),不会对正式的数据库造成影响 Test Model 到现在我们主要的业务逻辑代码在model和view里面,所以

frist Django app— 二、 Model和管理界面

Django是符合MVC架构的,这里现学习M—Model,而且Django自带了一个管理model(数据库)的界面,所以一并学习. Database 配置 编辑Django的配置文件settings.py进行配置 添加polls app,修改后如下 INSTALLED_APPS = [ 'django.contrib.admin', # 管理界面 'django.contrib.auth', # 认证系统 'django.contrib.contenttypes', # 框架的content t

frist Django app — 三、 View

前面已经说过了Django中model的一些用法,包括orm,以及操作的api,接下来就是搭一些简单的界面学习view——Django中的view.主要介绍以下两个方面: url映射 请求处理 模板文件 url映射和请求处理共同构成了MVC中的C——controller,这里面涉及了url的写法(主要是正则表达式),接收页面传递过来的参数.在Django中可以使用template来进行页面渲染,这样可以直接使用传递过来的数据. url映射 这里紧接着上一篇的工程完善polls项目,polls网站

frist Django app — 四、 完善View

上一篇已经完成了polls的基本功能,接下来完善剩下的vote功能和并使用generic views改进请求处理view.包含表单的简单运用和前后台参数传递. 目录 vote:完善投票功能 generic views:改进views.py vote 编辑detail.html,添加投票投票功能 <h1>{{question.question_text}}</h1> {% if error_message %}<p><strong>{{ error_messa

Django学习手册 - 创建Django工程项目以及APP

前置步骤: 下载python,django 并且安装好 python 解释器以及django模块. 整体步骤阐述: 创建django工程项目 步骤一:进入安装的python目录 步骤二:输入创建工程的命令: 创建业务APP目录 步骤一:进入已创建的工程项目目录 步骤二:输入创建APP 工程项目名称 创建django工程项目: 1.进入安装的python目录下的scripts 目录中 2.在此文件夹的空白处 shift + 鼠标右键  ,在此处打开命令窗口 3.在此窗口下输入: 1 django-

Ubuntu下Django初体验(二)——创建工程及应用

一.工程目录详解 创建工程后得到如下目录: 1. manage.py 管理项目.创建数据库.启动服务器等.测试等. 查看子命令: python manage.py 启动服务器: python manage.py runserver 指定启动服务器的地址和端口: python manage.py runserver 0.0.0.0 8080 2. mysite 目录 2.1 settings.py  对于整个网站的配置.配置文件:应用.中间件.数据库.静态目录各类配置... 2.2 urls.py

django (三) 第一个django app 创建model

经过上一章,我们已经创建好一个django app了,接下来,我们开始完善它. 首先,我们先了解些基本概念. Django中创建的每个应用程序都是由Python的包组成,遵循某些约定.Django配有一个实用程序,自动生成一个应用程序的基本目录结构,所以您可以专注于编写代码,而不是创建目录. 那么项目和应用程序到底有什么区别呢? 一个app是一个web应用:比如一个博客系统,一个简单的投票系统.而一个项目是一个集合的配置和应用程序特定的Web站点.一个项目可以包含多个应用程序.应用程序可以存在于

django创建工程,用命令

django创建工程的命令 >>python C:\Python33\Lib\site-packages\django\bin\django-admin.py startproject projectmanage >>cd projectmanage >>python C:\Python33\Lib\site-packages\django\bin\django-admin.py stratapp projectmanageapp >>mkdir templ