热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

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

这篇文章主要介绍了Windows下Python的Django框架环境部署及程序编写入门,Django在Python的框架中算是一个重量级的MVC框架,本文将从程序部署开始讲到hellowworldweb应用的编写,需要的朋友可以参考下
环境搭建
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 = "
".str(join(Job.objects.all())) return HttpResponse(str_count + "
" + 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文件内容

 
 
  
   
  {% block extrahead %}{% endblock %} 
  
  
  {% block content %}{% endblock %} 
  
 
template/mytemp目录下的base.html内容
[html] view plain copy
{% extends "base.html" %} 
 
{% block extrahead %} 
   
{% endblock %} 

template/mytemp目录下的job_list.html

{% extends "jobs/base.html" %} 
 
{% block title %}Job List{% endblock %} 
 
{% block content %} 
  

Job List

{% endblock %}

template/mytemp目录下的job_detail.html

{% extends "mytemp/base.html" %}
{% block title %}Job Detail{% endblock %}
{% block content %}
  

Job Detail

{{ job.job_title }} - {{ job.location }}

Posted: {{ job.pub_date|date:"d-M-Y" }}

{{ job.job_description }}

{% 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\d+)/$',('mydjango.myapp.views.detail')),

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

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

推荐阅读
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文介绍了django中视图函数的使用方法,包括如何接收Web请求并返回Web响应,以及如何处理GET请求和POST请求。同时还介绍了urls.py和views.py文件的配置方式。 ... [详细]
  • 本文介绍了使用cacti监控mssql 2005运行资源情况的操作步骤,包括安装必要的工具和驱动,测试mssql的连接,配置监控脚本等。通过php连接mssql来获取SQL 2005性能计算器的值,实现对mssql的监控。详细的操作步骤和代码请参考附件。 ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 31.项目部署
    目录1一些概念1.1项目部署1.2WSGI1.3uWSGI1.4Nginx2安装环境与迁移项目2.1项目内容2.2项目配置2.2.1DEBUG2.2.2STAT ... [详细]
author-avatar
感激遇见彭
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有