专栏首页北京马哥教育【Django新人必看】Django安装及搭建开发环境实战细解

【Django新人必看】Django安装及搭建开发环境实战细解

开笔有话说

接触django有一段时间了,发现国内网站上的django学习资料,虽然有不少,但大多有老旧的通病,所基于的版本简直是太旧了,就拿《the django book》来说,这本书应该是很多人接触django的第一本教程了,可是居然是基于1.1版本的……要知道,现在已经出了1.11版本的django了,这中间差了多少?

教程版本落后,在实战学习中往往会出现很多兼容性问题,笔者当时就吃了不少这方面的亏,学习1.1的教程,拿1.8的版本来实践,可想而知,得有多少坑……没办法,谁让国内django方面的实战案例教程如凤毛麟角呢?最后,只能拿来1.8版本的api文档啃英文了。

鉴于以上,笔者想写一系列实战教程,针对最新的django版本,与大家分享,为新手们学习django提供捷径,同时巩固个人知识体系,如有笔误,欢迎大神们指点一二。

案例介绍

在这个实战项目里,我们会从头开始,一步步搭建一个完整的blog站点。从开发环境到生产环境的发布,会分成几部分文章来完成。

请注意,此为实战项目教程,不会从头讲基础的django知识。建议有一定的django基础后再阅读该系列文章。

该实战项目主要包含以下几个部分:

基本部分

  • 安装django,搭建隔离的开发环境
  • 创建工程及数据库基本配置
  • 创建blog应用并对其建立模型
  • 搭建blog站点的后台管理系统admin
  • 利用bootstrap框架和django的模板及视图系统构建前端基本页面
  • 增加分页

增强部分

  • 实现发送邮件功能
  • 创建表单及其处理
  • 创建基于模型的表单
  • 集成第三方应用
  • 构建复杂的查询集

进一步扩展

  • 创建自定义模板标签
  • 创建自定义模板过滤器
  • 添加站点地图sitemap
  • 添加订阅
  • 利用Solr和Haystack建立站内搜索引擎

版本说明

本项目要用到的软件及版本如下

  1. python==2.7+
  2. django==1.8.6
  3. virtualenv==13.1.2

下面咱们正式开始进行blog项目的开发。

建立隔离的开发环境

开发项目的第一点,也是首要的,就是建立一个隔离的开发环境,避免污染本机系统,同时保证不同版本的控制与隔离。其重要性,这里不再赘述,以后会单独写一篇文章具体讲述,以及如何使用virtualenv。

1.创建一个新的目录

2.在新目录myproject中,建立独立的python运行环境

命令virtualenv venv就可以创建一个独立的Python运行环境venv,我们还加上了参数--no-site-packages,这样,已经安装到系统Python环境中的所有第三方包都不会复制过来,这样,我们就得到了一个不带任何第三方包的“干净”的Python运行环境。

可看到在myproject目录下生成了一个新的文件夹venv,里面包含bin、include、lib三个目录,即组成了新的、干净的、隔离的python运行环境。

3.激活运行环境

运行下面这行命令就能激活上面建立的隔离的python运行环境

如上所示,在命令行的前面出现(venv)前缀,即表示我们刚刚建立的隔离环境venv已被成功激活。这时所有的操作都是在venv这个Python独立的运行环境下,不会受外界系统python环境的影响,也不会影响到外界系统的Python环境。 此时,在此环境下安装的所有的python包都会被默认安装到venv/lib/python2.7/site-packages/目录下。

【补充】注销激活,deactivate即可。

安装Django

安装Django,版本1.8.6

隔离的环境搭建好了,接着就可以安装django了。 利用命令pip install Django==1.8.6,就可安装指定版本为1.8.6的django了。当然,安装django的方法有多种,我们在这里选择最方便的一种,直接用pip安装。因为在创建venv隔离环境的时候,已经预装好了pip,所以这里用pip安装django就很方便了,就是一句命令的事儿。以后在该项目中所有用到的python包,我们都会直接用pip来安装。

安装完成。 在venv/lib/python2.7/site-packages/目录下会看到新增加Django-1.8.6.dist-info/和django/文件夹。

验证是否成功安装

方法1:pip list

会发现有Django (1.8.6),说明已安装Django,而且可看出其版本为1.8.6。

方法2:import django

打开python命令终端

导入django包,

成功打印出django的版本,到此,则表示django已成功安装。

作者:地球的外星人君 来源:https://zhuanlan.zhihu.com/p/28125085


本文分享自微信公众号 - 马哥Linux运维(magedu-Linux),作者:地球的外星人君

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2017-07-26

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 如何判断目标站点是否为Django开发

    老文一篇,几个月以前发在【代码审计】小密圈里的文章,当时是写一个系列(Django安全漫谈),抽出其中的一部分,分享一下。 在黑盒测试的情况下,如何判断一个站是...

    小小科
  • Linux进程及作业管理

    一、进程查看及其管理工具 ps命令:报告当前进程的快照信息 ps - report a snapshot of the current processes....

    小小科
  • python,django做中间件屏蔽非法访问

    我使用django1.6. django框架没有urlfilter这样的原生中间件,但是灵活的django设计者为我们留下了更自由的渠道。 在没有使用djan...

    小小科
  • Django学习_简易博客(一)

    zx钟
  • 1000个常用的Python库和示例代码

    下面是programcreek通过分析大量开源代码,提取出的最常用的python库。

    用户4962466
  • django基础

    小小咸鱼YwY
  • Django环境搭建

    在学习python语言的过程中,不得不学习django,理由很简单的,就是django有一个很优秀的框架,特别是它提供了一个admin的后台,这样在不浪费什么精...

    无涯WuYa
  • 大白话讲解django之创建一个django项目

    django 非常强大,尤其是django rest framework 打造REST API 非常方便。这次我们先创建一个项目,看看 django 正常运行之...

    用户4945346
  • Django开发社交类网站必备的10个第三方应用

    Django 的好处就是大而全,不仅内置了 ORM、表单、模板引擎、用户系统等,而且第三方应用的生态也是十分完善,开发中大部分常见的功能都能找到对应的第三方实现...

    追梦人物
  • CVE-2020-7471 Django StringAgg SQL Injection漏洞复现

    近日,Django 官方发布安全通告公布了一个通过StringAgg(分隔符)的潜在SQL注入漏洞(CVE-2020-7471)。

    墙角睡大觉

扫码关注云+社区

领取腾讯云代金券