原文地址是:http://zeroandone.posterous.com/top-10-tips-to-a-new-django-developer

1,不要将项目名称包含在引用代码里

比如你创建了一个名为"project"的项目,包含一个名为"app"的应用,那么如下代码是不好的:

Python代码  
  1. from project.app.models import Author

缺点在于:应用和项目变成了紧耦合,无法将应用轻易变得可重用。如果将来要换一个项目名称,那你可有得受了。

推荐的做法是:

Python代码  
  1. from app.models import Author

请注意,你需要将项目的路径配置在PYTHONPATH中。

2,不要硬编码MEDIA_ROOT和TEMPLATE_DIRS

项目配置文件settings.py中不要使用如下代码:

Python代码  
  1. TEMPLATE_DIRS = ( "/home/html/project/templates",)
  2. MEDIA_ROOT = "/home/html/project/appmedia/"

当你在部署到生产环境,或者迁移服务器的时候,就会发生问题。

推荐使用如下方式:

Python代码  
  1. SITE_ROOT = os.path.realpath(os.path.dirname(__file__))
  2. MEDIA_ROOT = os.path.join(SITE_ROOT, 'appmedia')
  3. TEMPLATE_DIRS = ( os.path.join(SITE_ROOT, 'templates'),)

(也可以使用abspath,跟realpath的区别请参考http://rob.cogit8.org/blog/2009/May/05/django-and-relativity-updated/ )

3,不要将静态文件的路径硬编码在模板中

模板中链接CSS,javascript或图片的时候,不建议使用如下方式:

Html代码  
  1. <link rel="stylesheet" type="text/css" href="/appmedia/amazing.css" />
  2. <script type="text/javascript" src="/appmedia/jquery.min.js"></script>

当你的项目需要将静态文件用其他服务器提供的时候,通常会是另外一个http地址,那么你就得把所有的/appmedia/替换成新的地址,做网站写代码已经够乏味的了。

没有后顾之忧的解决方法是使用{{ MEDIA_URL }}代替硬编码的路径:

Html代码  
  1. <link rel="stylesheet" type="text/css" href="{{ MEDIA_URL }}amazing.css" />
  2. <script type="text/javascript" src="{{ MEDIA_URL }}jquery.min.js"></script>

模板上下文变量怎么获取到呢?请使用RequestContext即可:

Python代码  
  1. return render_to_response("app/template.html", {'var': 'foo'},
  2. context_instance=RequestContext(request))

从RequestContext里还可以获取到当前用户等信息,更详细的介绍请参考:http://www.b-list.org/weblog/2006/jun/14/django-tips-template-context-processors/

4,不要将业务逻辑代码写到视图里

不要迷惑,虽然你可能看过很多书和例子,它们把逻辑都写在了views.py里,但请你别这么做。因为这样不利于单元测试,不利于重用代码。

那我的业务逻辑应该放哪里呢?推荐放到模型里或者单独建立一个辅助(helper)模块。

当然,从模型得到一个Author,获取Author列表的代码是可以放到视图里面的。

5,部署时别忘记将DEBUG设置成False

我们常常忘记在部署时禁用DEBUG,有很多种方法自动来处理这个配置:

Python代码  
  1. import socket
  2. if socket.gethostname() == 'productionserver.com':
  3. DEBUG = False
  4. else:
  5. DEBUG = True

此方法请参考:http://nicksergeant.com/blog/django/automatically-setting-debug-your-django-app-based-server-hostname

另一种途径是使用不同的配置文件:

Python代码  
  1. #文件名:settings_debuy.py
  2. #包含调试模式的配置信息
  3. #使用python manage.py runserver settings=settings_debug.py来运行项目
  4. from settings import *
  5. DEBUG = True
  6. #还可以配置更多在调试时使用的变量:)

此方法请参考:http://blog.dpeepul.com/2009/07/02/from-now-you-will-never-forget-to-put-debug-true-in-django-production-environment/

6,只加载一次自定义的模板标签

当需要使用自定义或者第三方的模板标签和模板过滤器时,通常要在模板中使用:

Python代码  
  1. {% load template_tags %}

实际情况是,需要在所有用到自定义模板标签和模板过滤器的模板中都使用上面的代码,这样就不DRY了。

Python代码  
  1. from django import template
  2. template.add_to_builtins('app.templatetags.custom_tag_module')

请将以上代码放到项目启动时能加载的模块中(settings.py, urls.py, models.py等)即可。

上面代码的作用是在项目启动时就把自定义模板标签或过滤器加载进来,模板中任何一个地方都可以使用它们,而不需要{% load template_tags %}。

7,合理配置和使用URL

不要将URL全都配置在一个urls.py文件中,比如:

Python代码  
  1. urlpatterns = patterns('',
  2. url(r'^askalumini/question/$','.....registerInstitution',name='iregister'),
  3. url(r'^askalumin/answer/$','someview.....',name='newmemberurl'),
  4. url(r'^institution/member/$','someview.....',name="dashboardurl"),
  5. url(r'^institution/faculty/$','editInstitute',name="editinstituteurl"),
  6. url(r'^memeber/editprofile/$','editProfile',name="editprofileurl"),
  7. url(r'^member/changepassword/$','changePassword',name="changepasswordurl"),
  8. url(r'^member/forgotpassword/$','forgotPassword',name="forgotpasswordurl"),
  9. url(r'^member/changepicture/$','changePicture',name="changepictureurl"),
  10. url(r'^member/logout/$','memeberlogout',name="logouturl"), ,
  11. )

建议的方式是将各应用的URL配置在各自的urls.py中,这样可以使应用更容易重复使用到不同项目里:

Python代码  
  1. urlpatterns = patterns('',
  2. (r'^$', include('institution.urls')),
  3. (r'^institution/', include('institution.urls')),
  4. (r'^askalumini/', include('askalumini.urls')),
  5. (r'^member/', include('member.urls')),
  6. )

如下是应用askalumini的urls.py:

Python代码  
  1. urlpatterns = patterns('askalumini.views',
  2. url(r'^$','askHome',name='askaluminiurl'),
  3. url(r'^questions/(?P<questionno>\d+)/$','displayQuestion',name='askquestiondisplay'),
  4. url(r'^askquestions/$','askQuestion',name='askquestionurl'),
  5. url(r'^postcomment/$','postComment',name="askquestioncomment")
  6. )

刚才提到静态文件路径不要硬编码,url的处理方式也尽量不要硬编码,否则当你更改一个地址时会牵涉到多处的修改,可以使用一些url函数来处理。

在/project/askalumini/urls.py中,为每一个url定义了name,它可以帮助我们有效地在视图、模板和模型中处理url,而不是硬编码。

为保证名称的唯一,请遵照将url命名为<appname>/<somelabel>的习惯用法。

举例来说,在views.py文件中有如下代码:

Python代码  
  1. HttpResponseRedirect("/askalumini/questions/54")

请改为:

Python代码  
  1. from django.core.urlresolvers import reverse
  2. HttpResponseRedirect(reverse('askquestiondisplay',kwargs={'questionno':q.id}))

在模型中使用models.permalink装饰器来格式url:

Python代码  
  1. @models.permalink
  2. def get_absolute_url(self):
  3. return ('profileurl2',(),{'userid': self.user.id})

在模板中使用url标签代替硬编码:

Html代码  
  1. {% url askquestiondisplay 345 %}
  2. <a href="{% url askquestiondisplay 345 %}"> Ask Question </a>

8,调试

调试通常会借助一些第三方工具来获得更多的运行时信息。

一个请求执行了多少句SQL?花了多长时间?

调用的哪个模板?客户端设置了什么COOKIE?SESSION呢?。。。

你可以使用django-debug-toolbar查看上面甚至更多的信息:http://github.com/robhudson/django-debug-toolbar

另一个工具是Werkzeug debugger,它可以在错误页面打开python shell,让你更方便的跟踪错误信息,请访问:http://blog.dpeepul.com/2009/07/14/python-shell-right-on-the-django-error-page/ 获得更多信息。

还有pdb,一个强大的调试工具:http://ericholscher.com/blog/2008/aug/31/using-pdb-python-debugger-django-debugging-series-/

9,了解pinax备用

django最大的优点是代码重用,DRY,pinax就是这样一个平台,包含了许多可拿来直接使用的代码,比如openid,电子邮件验证等等。请访问:http://pinaxproject.com/

10,了解一些著名的第三方应用

1)数据库升级工具

什么是数据库升级工具?你运行了syncdb,运行了一年之后,对模型做了更改,添加了字段,删除了字段,要再运行syncdb吗?或者ALTER TABLE ...?

django-evolutions可以帮你完成上面的事情,但它好像不够强壮:http://code.google.com/p/django-evolution/

South能很强壮地完成上面的事情,但是需要学学怎么用:http://south.aeracode.org/

2)模板系统

django自带的模板系统是可以替换的,并且各自有优缺点。

template-utils增强了模板的比较标签等功能 ,并提供其他的一些实用特性:http://django-template-utils.googlecode.com/svn/trunk/docs/

Jinja是一个完整的第三方模板系统,可以替换默认模板系统,它提供了许多优越的特性:http://jinja.pocoo.org/2/

3)第三方应用

django command extensions提供了很多实用的命令行功能:

shell_plus加载所有django模型

runserver_plus整合了Werkzeug调试工具

生成模型图表,你可以展示给你的老板

……

请参考:http://ericholscher.com/blog/2008/sep/12/screencast-django-command-extensions/

Sorl可以生成缩略图:http://code.google.com/p/sorl-thumbnail/

…………

---END---

另外,从原文的评论里也有不少发现:

  • 用django.shortcuts的redirect代替HttpResponseRedirect:http://docs.djangoproject.com/en/dev/topics/http/shortcuts/#redirect
  • 使用VirtualEnv部署django项目
  • django项目规范:http://ericholscher.com/projects/django-conventions/project/
  • 上面提到的10点中,第2和第4是最容易在新手中发生的。
  • 第6点并不适合于团队协作

转载于:https://www.cnblogs.com/SophiaTang/archive/2011/12/31/2308176.html

转:Django新手需要注意的10个要点相关推荐

  1. Django新手需要注意的10个要点

    2019独角兽企业重金招聘Python工程师标准>>> 这篇博文对于django的要点总结很不错,翻译感觉也不错,这里收藏学习,提醒自己不要偷懒,记住要写优美的代码! 1,不要将项目 ...

  2. oracle10个,OracleDBA新手经常碰到的10个Oracle错误

    OracleDBA新手经常碰到的10个Oracle错误(英文) This document contains information about errors frequently encounter ...

  3. Django最新版(1.10.5)在SAE上面部署流程

    Django最新版(1.10.5)在SAE和Pythonanywhere上面部署流程 一.Django在SAE上的部署 1.注意事项: 将整个Django项目准备好,是Project,不是app. S ...

  4. Django新手入门(五)——Models详解

    Django新手入门(五)--Models详解 数据库 ORM Django中的ORM Django中的Models 定义models.py中的类 常用数据字段 常用设置选项 常用函数以及修饰词 其他 ...

  5. SEO优化新手必须掌握的10个技巧和工具

    随着互联网的不断发展,SEO(搜索引擎优化)已成为网站拓展和推广的重要手段之一.对于新手而言,学习SEO的基础知识和技巧是至关重要的.在本文中,我将分享SEO优化新手必须掌握的10个技巧和工具. 1. ...

  6. 成为优秀高级程序员的10个要点

     成为优秀高级程序员的10个要点 What 软件工程师的职业生涯要历经以下几个阶段:初级.中级,最后才是高级.这篇文章主要是讲如何通过10个步骤助你成为一名高级软件工程师. Why 得到更多的报酬 ...

  7. Android 10适配要点,作用域存储

    本文同步发表于我的微信公众号,扫一扫文章底部的二维码或在微信搜索 郭霖 即可关注,每个工作日都有文章更新. 距离Android 10系统正式发布已经过去大半年左右的时间了,你的应用程序已经对它进行适配 ...

  8. 总结Android手机应用UI设计的10个要点

    总结Android手机应用UI设计的10个要点 (本文经游戏邦授权转载,原文链接http://gamerboom.com/archives/48018) 作者:Guenther Beyer 最近,许多 ...

  9. 【AI初识境】给深度学习新手做项目的10个建议

    这是专栏<AI初识境>的第12篇文章.所谓初识,就是对相关技术有基本了解,掌握了基本的使用方法. 在成为合格的深度学习算法工程师,尤其是工业界能够实战的调参选手之前,总会踏足很多的坑. 今 ...

  10. 简约而不简单的 Django 新手图文教程

    来源:cizixs segmentfault.com/a/1190000008387882 本文面向:有python基础,刚接触web框架的初学者. 环境:windows7,python3.5.1,p ...

最新文章

  1. ×××的各种协议介绍
  2. 跨链Cosmos(4)Tendermint Core
  3. WIN32多线程抢红包练习
  4. VTK:量化多数据点用法实战
  5. ElastieSearch安装以及与Mongodb的概念对照关系
  6. SAP Cloud for Customer的Container应用设计原理
  7. 使用verilog设计实现QR分解
  8. 关于迪杰斯特拉算法(最短路)的PHP实现
  9. js高级—查询商品案例
  10. 加载中_GIS地图在项目中的加载显示
  11. 为了让你的网页能在更多的服务器上正常地显示,还是加上“SET NAMES UTF8”吧
  12. WORD如何插入域编号?
  13. 编程语言对比 主程序传参
  14. 企业如何实现大数据分析平台
  15. 软件公司产品营销大数据分析(上)
  16. 2021-09-08因子分解机
  17. 、谷歌离线地图开发教程
  18. 什么是数据恢复工具,一款一键恢复软件
  19. Maxscript-通用事件反馈
  20. android视频自动旋转,Android 使用PLDroidPlayer播放网络视频 根据视频角度自动旋转...

热门文章

  1. 为什么计算机无法访问u盘,打开U盘后为什么提示拒绝访问 打开U盘后提示拒绝访问原因...
  2. 监督学习算法的发展史和它们之间的关系:从文氏图到回归、决策树、支持向量机和人工神经网络
  3. 常见排序算法02之插入排序与希尔排序
  4. iphone,ipad,android图片尺寸
  5. 设有一个线性表E = { e1, e2, … , en - 1, en },设计一个算法,将线性表逆置,即使元素排列次序颠倒过来,成为逆线性表E'={ en , en-1 , … , e2 , e1
  6. Unity 动态编辑Terrain地形(五)贴图
  7. 从银行、保险到证券,揭开大数据在金融行业的应用
  8. 数据库系统原理与应用教程(041)—— MySQL 查询(三):设置查询条件
  9. java软件制作教程_Minecraft Java版材质包制作教程
  10. MySQL讲义第 46 讲——select 查询之查询练习(四)