Windows下Python的Django框架环境部署及应用编写入门

环境搭建
1、下载所需的软件包:
(1)python安装包
(2)django安装包
以下2个包其实是安装python包管理工具,在后面安装django文档包模块时会用到,下载网站是pypi
(1)setuptools.exe 
(2)pip

2、安装所需的软件包:
python安装包是exe,setuptools也是exe,所以直接双击安装即可,先安装
django、pip是python模块包:安装时先解压,而后进入目录后使用命令:python setup.py install 安装即可

3、测试python及django
python和setuptools因为是exe安装方式,已经帮你添加了环境变量,安装后可以直接使用
django、pip安装后需要手动把它们的安装目录添加到环境变量
新起cmd:输入python,看到能进入python交互解释器则python没有问题
输入django-admin.py --help 能看到使用帮助提示则说明安装成功

4、建立第一个django项目:
以下cmd命令会在当前目录下建立一个django项目djangoproject1:

django-admin.py startproject djangoproject1

这个项目目录下有4个文件:

__init__.py
manage.py   ###功能与django-admin.py相同的文件,只是这个主要用于管理当前项目
settings.py   ###当前项目的设置文件,比如:webapp目录的设置、数据库连接的设置、模板目录的设置等
urls.py       ###当前项目url导航的设置,用一个正则匹配模式这匹配url规则并映射到指定的文件去处理请求

5、安装django自带的admin应用,即安装一个webapp
修改setting.py文件中的如下内容:

DATABASES = {
  'default': {
    'ENGINE': 'sqlite3', #设置使用sqlite3数据库
    'NAME': r'C:\Users\。。。。\test.db',           # sqlite3的文件路径
    'USER': '',           # Not used with sqlite3.
    'PASSWORD': '',         # Not used with sqlite3.
    'HOST': '',           # Set to empty string for localhost. Not used with sqlite3.
    'PORT': '',           # Set to empty string for default. Not used with sqlite3.
  }
} 

INSTALLED_APPS = (
  'django.contrib.auth',
  'django.contrib.contenttypes',
  'django.contrib.sessions',
  'django.contrib.sites',
  'django.contrib.messages',
  'django.contrib.staticfiles',
  # Uncomment the next line to enable the admin:
  'django.contrib.admin',  ##取消原来的注释
  # Uncomment the next line to enable admin documentation:
  'django.contrib.admindocs',  ##取消原来的注释
)

修改urls.py问件中的如下内容:

# Uncomment the next two lines to enable the admin:
from django.contrib import admin ##取消注释
admin.autodiscover()  ##取消注释 

  # Uncomment the admin/doc line below to enable admin documentation:
  url(r'^admin/doc/', include('django.contrib.admindocs.urls')),  ###取消注释 

  # Uncomment the next line to enable the admin:
  url(r'^admin/', include(admin.site.urls)),  ###取消注释

6、同步admin应用的数据库:
在项目主目录下使用命令:

manage.py syncdb

会提示创建一个超级用户,输入yes并按照提示创建一个账号即可

7、测试admin应用:
使用命令启动django的服务:

manage.py runserver

浏览器中输入地址:http://127.0.0.1:8000/admin/
如果出现登录界面则说明admin应用安装成功,使用第6步中创建的账号登录即可

8、安装admin的文档模块:
命令行输入:

pip install docutils

安装完成后重启django服务,访问地址http://127.0.0.1:8000/admin/doc/

9、使用和学习admin应用:
这个应用主要用于管理项目的应用的,同样可以很方面的管理数据库内容,如果想自己的项目也能在这里被管理则需要进行一个配置即可,后面将会有相关操作
默认其功能有:管理admin应用的用户、用户组;添加站点

10、创建自己的应用:
项目主目录下使用命令:

manage.py startapp myapp

命令会在当前目录下创建一个app的目录mysite,其下有文件:

__init__.py
models.py   ##用于创建数据模型的,即设计数据库结构的,在这里面配置到数据库的模块,django会自动帮你创建相应的数据库表结构
views.py    ##视图文件,用于响应用户请求并在处理后返回结果,这里面主要编写请求事件的响应函数

11、安装自己的应用:
和安装admin应用一样,修改settings.py文件

INSTALLED_APPS = (
    ......
    'djangoproject1.myapp',    ###添加这一句
)

12、创建第一个页面:
修改mysite目录下的views.py文件,内容如下:

from django.http import HttpResponse 

def home(request):
  return HttpResponse("Hello Django")

13、设置url请求页面:
修改urls.py内容如下:

urlpatterns = patterns('',
  # Examples:
  url(r'^$', 'djangoproject1.myapp.views.home', name='home'), )

14、测试自己的应用:
重启django服务,

manage.py runserver

访问:http://127.0.0.1:8000
如果出现:hello django 则说明设置成功

第一个app实现
在环境搭建好了的基础上我们还要继续做的就是往里面填内容了。也就是网页的实际内容,比如:页面内容,比如数据库内容,比如模块内容,比如css,js内容等,那么在django中是怎么整合这些的,在这里记录一下。
1、创建一个模式:
模式其实就是整个网站的数据模型,也就是数据库的结构,即数据表结构,所以创建一个模式就是设计一张数据表,只不过在django的模式里用代码形式来表示模式,然后它会帮助你自动生成响应的数据表及对应的关系,而且对支持的数据库都是统一的表示形式,即兼容性不错,是不是很方便啊!样例见下:
编写app目录中的models.py文件

from django.db import models 

class Location(models.Model):
  city = models.CharField(max_length=50)
  state = models.CharField(max_length=50, null=True, blank=True)
  country = models.CharField(max_length=50)
  def __str__(self):
    if self.state:
      return "%s, %s, %s" % (self.city, self.state, self.country)
    else:
      return "%s, %s" % (self.city, self.country) 

class Job(models.Model):
  pub_date = models.DateField()
  job_title = models.CharField(max_length=50)
  job_description = models.TextField()
  location = models.ForeignKey(Location)
  def __str__(self):
    return "%s (%s)" % (self.job_title, self.location)

2、让模式生效:
在模式设计好了后就可以使用它,让它帮你干活啦,查看模式创建的表是否正确的命令为:manage.py sql app_dir,  这样可以查看表结构的原型了。在检查完表结构原型后就应用之,命令为:manage.py syncdb, 这个其实就是真正的在数据库中建表。

3、如何应用模式:
模式依然生效后就是如何去应用它,也就是获取其中的数据为我们服务;在views.py文件中包括如下代码即可调用具体的数据表;

from django.template import Context, loader
from django.http import HttpResponse
from myapp.models import Job 

def home(request):
  object_list = Job.objects.order_by('-pub_date')[:10]
  str_count = "The Count of job table is %s"%Job.objects.count()
  str_job_desc = "<br>".str(join(Job.objects.all())) 

  return HttpResponse(str_count + "<br>" + str_job_desc)

重启django,访问http://127.0.0.1:8000,如果出现字符信息说明正确,只是这时显示的是数据数据总数为0,内容为空而已

4、在admin中配置我的应用:
上面的内容没有数据,那么就造一些数据:一种是自己写sql去造;不过还有一种方法就是在admin应用中去造数据,当然首先是配置admin来管理我创建的应用。在我的应用目录中新建一个admin.py文件,其内容如下:

from django.contrib import admin
from mydjango.myapp import models 

class DocumentAdmin(admin.ModelAdmin):
  pass 

class CommentAdmin(admin.ModelAdmin):
  pass 

admin.site.register(models.Location, DocumentAdmin)
admin.site.register(models.Job, CommentAdmin)

重启django,访问http://127.0.0.1:8000/admin, 就可以看到我的应用中的数据可以在这里管理了。

5、在admin中管理我的应用:
在admin中设置好我的应用后,就可以通过admin来为我的应用添加数据了。具体就是点击添加、输入内容、保存即可。等有了数据后我们在回到主页看看是不是页面内容就由内容了?

6、开始设置模板:
内容少的时候我们可以每个页面都自己写,但是当页面变多,而且还有很多相同部分时,我们就希望能不要写那些同样的东西了,那么模板就是为了解决这样的问题而出现的,在django中配置模板的方法是在项目主目录的settings.py文件中修改如下内容:

TEMPLATE_DIRS = (
  "C:/Users/xiaowu/workspace/mydjango/templates", ##注意斜线的格式,是/而不是\,即使在windows下
)

7、创建模板文件:
在settings.py文件设置的模板目录下新建模板文件,模板文件其实都是html文件,只是其中的内容包含一些特殊的占位符,在实际应用中会替换掉其中的内容;这些内容就是在代码里实现出来的数据了;而且模板还可以继承,这个也比较好用,就好像程序的代码块一样分的越细可重用性就越好。样例如下:
template主目录下的base.html文件内容

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
 <head>
  <title>Company Site: {% block title %}Page{% endblock %}</title>
  {% block extrahead %}{% endblock %}
 </head>
 <body>
  {% block content %}{% endblock %}
 </body>
</html>
template/mytemp目录下的base.html内容
[html] view plain copy
{% extends "base.html" %} 

{% block extrahead %}
  <style>
    body {
      font-style: arial;
    }
    h1 {
      text-align: center;
    }
    .job .title {
      font-size: 120%;
      font-weight: bold;
    }
    .job .posted {
      font-style: italic;
    }
  </style>
{% endblock %}

template/mytemp目录下的job_list.html

{% extends "jobs/base.html" %} 

{% block title %}Job List{% endblock %} 

{% block content %}
  <h1>Job List</h1>
  <ul>
  {% for job in object_list %}
    <li><a href="{{ job.id }}">{{ job.job_title }}</a></li>
  {% endfor %}
  </ul>
{% endblock %}

template/mytemp目录下的job_detail.html

{% extends "mytemp/base.html" %}
{% block title %}Job Detail{% endblock %}
{% block content %}
  <h1>Job Detail</h1>
  <div class="job">
    <div class="title">
      {{ job.job_title }}
      -
      {{ job.location }}
    </div>
    <div class="posted">
      Posted: {{ job.pub_date|date:"d-M-Y" }}
    </div>
    <div class="description">
      {{ job.job_description }}
    </div>
  </div>
{% endblock %}

8、应用模板文件:
在django中是在views.py中具体的引用模板,具体方法见下:
方法一:

from django.template import Context, loader
from django.http import HttpResponse
from myapp.models import Job 

def home(request):
  object_list = Job.objects.order_by('-pub_date')[:10]
  t = loader.get_template('mytemp/job_list.html')
  c = Context({
    'object_list': object_list,
    })
  return HttpResponse(t.render(c))

方法二:

from django.shortcuts import get_object_or_404, render_to_response
from myapp.models import Job 

def home(request,job_id):
  job = get_object_or_404(Job, pk=job_id)
  return render_to_response('mytemp/job_detail.html',
               {'object': job})

9、最后的views.py文件内容如下:

from django.template import Context, loader
from django.http import HttpResponse
from myapp.models import Job
from django.shortcuts import get_object_or_404, render_to_response 

def home(request):
  return HttpResponse("Hello Django") 

def index(request):
  object_list = Job.objects.order_by('-pub_date')[:10]
  t = loader.get_template('mytemp/job_list.html')
  c = Context({
    'object_list': object_list,
    })
  return HttpResponse(t.render(c))  

def detail(request,job_id):
  job = get_object_or_404(Job, pk=job_id)
  return render_to_response('mytemp/job_detail.html',
               {'object': job})

9、配置index、detail视图的url,在urls.py添加如下内容:

url(r'^job/$', ('mydjango.myapp.views.index')),
url(r'^job/(?P<job_id>\d+)/$',('mydjango.myapp.views.detail')),

然后重启服务后,访问http://127.0.0.1:8000/job/

ok,所有的结构都已经用到了,剩下的就是想出一个有趣的项目赶紧上手吧!

(0)

相关推荐

  • 在Windows8上的搭建Python和Django环境

    先从搭建环境开始.作为一个Python初学者来说,一个趁手的编译器是很重要的,本想用VS来开发Python,但是感觉实际开发中没有几家公司会用VS来开发Python,没办法就换成了MyEclipse. 一.首先下载和安装Myeclipse就略过了. 二.安装Python. 一般的开发环境是在linux,网上很多教程和视频也都是在linux下配置和开发的.我的开发环境是64位win8系统,先从官网下载64位的Python安装程序. 可以从这里选择要下载的版本 https://www.python.

  • windows+apache+mod_python配置django运行环境

    1.创建mysite测试站点:django-admin.py startproject mysite 2.创建测试页:hello.py,内容如下: from django.http import HttpResponse def index(request): return HttpResponse('Hello, Django!') 3.创建mod_py_dj.conf配置文件,内容如下: LoadModule python_module modules/mod_python_so.pyd L

  • Windows上使用virtualenv搭建Python+Flask开发环境

    关于virtualenv: VirtualEnv用于在一台机器上创建多个独立的Python虚拟运行环境,多个Python环境相互独立,互不影响,它能够: 1.在没有权限的情况下安装新套件 2.不同应用可以使用不同的套件版本 3.套件升级不影响其他应用 虚拟环境是在Python解释器上的一个私有复制,你可以在一个隔绝的环境下安装packages,不会影响到你系统中全局的Python解释器. 虚拟环境非常有用,因为它可以防止系统出现包管理混乱和版本冲突的问题.为每个应用程序创建一个虚拟环境可以确保应

  • Windows下Eclipse+PyDev配置Python+PyQt4开发环境

    本文为大家分享了Windows下配置Python PyQt4开发环境的详细步骤,供大家参考,具体内容如下 1. 下载相关软件 Eclipse下载地址:http://www.eclipse.org/downloads/ JRE下载地址:http://www.java.com/zh_CN/download/manual.jsp PyDev下载地址: http://sourceforge.net/projects/pydev/ Python下载地址:http://www.python.org/geti

  • windows下wxPython开发环境安装与配置方法

    安装文件准备: 安装文件 下载地址 python-2.6.2.msi http://www.python.org/download/ wxPython2.8-win32-unicode-2.8.10.1-py26.exe wxPython2.8-win32-docs-demos-2.8.10.1.exe http://www.wxpython.org/download.php py2exe-0.6.9.win32-py2.6.exe http://sourceforge.net/projects

  • Python+Django在windows下的开发环境配置图解

    1         安装配置开发环境 1.1   准备安装 下载以下软件 Eclipse for C/C++ SUN JDK 1.6 不一定要1.6,1.5的也可以 Python3.1  Python2.6.4  Pythone2.5.2 mod_python-3.3.1.win32-py2.5-Apache2.2 MySQL-python-1.2.2.win32-py2.5 pysqlite-2.5.5.win32-py2.5 python.pydev.feature-1.5.0.125198

  • Windows中安装使用Virtualenv来创建独立Python环境

    0.什么时候会用到virtualenv? 假设系统中的两个应用,其中A应用对库LibFoo的版本要求为1,而B应用对同一个库LibFoo的版本要求为2,两个应用对同一个库的要求想冲突了,而系统中库默认都安装到/usr/lib/python2.7/site-packages,那么如何能够同时使用这两个应用呢? 你的用户权限不够,使得无法将包安装到site-packages目录 需要使用一个应用,并且与系统其它应用相独立. 如果你遇到以上的问题,那么virtualenv会对你有帮助.virtuale

  • windows系统下Python环境搭建教程

    windows系统下Python环境的搭建 step1:下载Python程序 https://www.python.org/downloads/release/python-351/ 选择第一个下载下来(随随便下载哪个) step2:安装及配置环境 点击程序默认安装 step3:开发配置环境 电脑->系统->高级系统设置->环境变量->系统变量->path变量追加Python的安装路径 step:测试python安装是否成功 cmd打开命令行输入 python 命令 输入内容

  • Windows下搭建python开发环境详细步骤

    本文为大家分享了Windows下搭建python开发环境详细步骤,供大家参考,具体内容如下 1.搭建Java环境 (1)直接从官网下载相应版本的JDK或者JRE并点击安装就可以 (2)JDK与JRE的区别: 1)JDK就是Java Development Kit.简单的说JDK是面向开发人员使用的SDK,它提供了Java的开发环境和运行环境.SDK是Software Development Kit 一般指软件开发包,可以包括函数库.编译程序等 2)JRE是Java Runtime Envirom

  • 在Windows系统上搭建Nginx+Python+MySQL环境的教程

    1 安装nginx 下载windows上的nginx最新版本,http://www.nginx.org/en/download.html. 解压后即可. 运行nginx.exe后本地打开http://localhost,将会看到欢迎页面,这证明nginx在本地运行良好,如果没有出现欢迎页面,请检查是否有进程占用了80端口. 2 安装flup 下载对应版本的flup,这里下载flup3.x版本,适合python3.2,下载地址:https://github.com/chxanders/flup3

随机推荐