Django问题2
接触django是从上个月开始,学习python时间也不长,但我经常在社区看看别人发表的文章,早上看到一篇不错的博客,却一直不能访 问,最终从bing的缓存里找到,因为害怕丢失和忘掉,所以顺便翻译过来,放到这里,同时也分享给大家,贡献给各位django初学的朋友们,希望能有一 些帮助:)
原文地址是:http://zeroandone.posterous.com/top-10-tips-to-a-new-django-developer
1,不要将项目名称包含在引用代码里
比如你创建了一个名为"project"的项目,包含一个名为"app"的应用,那么如下代码是不好的:
Python代码
- from project.app.models import Author
缺点在于:应用和项目变成了紧耦合,无法将应用轻易变得可重用。如果将来要换一个项目名称,那你可有得受了。
推荐的做法是:
Python代码
- from app.models import Author
请注意,你需要将项目的路径配置在PYTHONPATH中。
2,不要硬编码MEDIA_ROOT和TEMPLATE_DIRS
项目配置文件settings.py中不要使用如下代码:
Python代码
- TEMPLATE_DIRS = ( "/home/html/project/templates",)
- MEDIA_ROOT = "/home/html/project/appmedia/"
当你在部署到生产环境,或者迁移服务器的时候,就会发生问题。
推荐使用如下方式:
Python代码
- SITE_ROOT = os.path.realpath(os.path.dirname(__file__))
- MEDIA_ROOT = os.path.join(SITE_ROOT, 'appmedia')
- 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代码
- <link rel="stylesheet" type="text/css" href="/appmedia/amazing.css" />
- <script type="text/javascript" src="/appmedia/jquery.min.js"></script>
当你的项目需要将静态文件用其他服务器提供的时候,通常会是另外一个http地址,那么你就得把所有的/appmedia/替换成新的地址,做网站写代码已经够乏味的了。
没有后顾之忧的解决方法是使用{{ MEDIA_URL }}代替硬编码的路径:
Html代码
- <link rel="stylesheet" type="text/css" href="{{ MEDIA_URL }}amazing.css" />
- <script type="text/javascript" src="{{ MEDIA_URL }}jquery.min.js"></script>
模板上下文变量怎么获取到呢?请使用RequestContext即可:
Python代码
- return render_to_response("app/template.html", {'var': 'foo'},
- 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代码
- import socket
- if socket.gethostname() == 'productionserver.com':
- DEBUG = False
- else:
- DEBUG = True
另一种途径是使用不同的配置文件:
Python代码
- #文件名:settings_debuy.py
- #包含调试模式的配置信息
- #使用python manage.py runserver settings=settings_debug.py来运行项目
- from settings import *
- DEBUG = True
- #还可以配置更多在调试时使用的变量:)
6,只加载一次自定义的模板标签
当需要使用自定义或者第三方的模板标签和模板过滤器时,通常要在模板中使用:
Python代码
- {% load template_tags %}
实际情况是,需要在所有用到自定义模板标签和模板过滤器的模板中都使用上面的代码,这样就不DRY了。
Python代码
- from django import template
- template.add_to_builtins('app.templatetags.custom_tag_module')
请将以上代码放到项目启动时能加载的模块中(settings.py, urls.py, models.py等)即可。
上面代码的作用是在项目启动时就把自定义模板标签或过滤器加载进来,模板中任何一个地方都可以使用它们,而不需要{% load template_tags %}。
7,合理配置和使用URL
不要将URL全都配置在一个urls.py文件中,比如:
Python代码
- urlpatterns = patterns('',
- url(r'^askalumini/question/$','.....registerInstitution',name='iregister'),
- url(r'^askalumin/answer/$','someview.....',name='newmemberurl'),
- url(r'^institution/member/$','someview.....',name="dashboardurl"),
- url(r'^institution/faculty/$','editInstitute',name="editinstituteurl"),
- url(r'^memeber/editprofile/$','editProfile',name="editprofileurl"),
- url(r'^member/changepassword/$','changePassword',name="changepasswordurl"),
- url(r'^member/forgotpassword/$','forgotPassword',name="forgotpasswordurl"),
- url(r'^member/changepicture/$','changePicture',name="changepictureurl"),
- url(r'^member/logout/$','memeberlogout',name="logouturl"), ,
- )
建议的方式是将各应用的URL配置在各自的urls.py中,这样可以使应用更容易重复使用到不同项目里:
Python代码
- urlpatterns = patterns('',
- (r'^$', include('institution.urls')),
- (r'^institution/', include('institution.urls')),
- (r'^askalumini/', include('askalumini.urls')),
- (r'^member/', include('member.urls')),
- )
如下是应用askalumini的urls.py:
Python代码
- urlpatterns = patterns('askalumini.views',
- url(r'^$','askHome',name='askaluminiurl'),
- url(r'^questions/(?P<questionno>\d+)/$','displayQuestion',name='askquestiondisplay'),
- url(r'^askquestions/$','askQuestion',name='askquestionurl'),
- url(r'^postcomment/$','postComment',name="askquestioncomment")
- )
刚才提到静态文件路径不要硬编码,url的处理方式也尽量不要硬编码,否则当你更改一个地址时会牵涉到多处的修改,可以使用一些url函数来处理。
在/project/askalumini/urls.py中,为每一个url定义了name,它可以帮助我们有效地在视图、模板和模型中处理url,而不是硬编码。
为保证名称的唯一,请遵照将url命名为<appname>/<somelabel>的习惯用法。
举例来说,在views.py文件中有如下代码:
Python代码
- HttpResponseRedirect("/askalumini/questions/54")
请改为:
Python代码
- from django.core.urlresolvers import reverse
- HttpResponseRedirect(reverse('askquestiondisplay',kwargs={'questionno':q.id}))
在模型中使用models.permalink装饰器来格式url:
Python代码
- @models.permalink
- def get_absolute_url(self):
- return ('profileurl2',(),{'userid': self.user.id})
在模板中使用url标签代替硬编码:
Html代码
- {% url askquestiondisplay 345 %}
- <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点并不适合于团队协作
Django问题2的更多相关文章
- 异步任务队列Celery在Django中的使用
前段时间在Django Web平台开发中,碰到一些请求执行的任务时间较长(几分钟),为了加快用户的响应时间,因此决定采用异步任务的方式在后台执行这些任务.在同事的指引下接触了Celery这个异步任务队 ...
- 《Django By Example》第四章 中文 翻译 (个人学习,渣翻)
书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:祝大家新年快乐,这次带来<D ...
- django server之间通过remote user 相互调用
首先,场景是这样的:存在两个django web应用,并且两个应用存在一定的联系.某些情况下彼此需要获取对方的数据. 但是我们的应用肯经都会有对应的鉴权机制.不会让人家随随便便就访问的对吧.好比上车要 ...
- Mysql事务探索及其在Django中的实践(二)
继上一篇<Mysql事务探索及其在Django中的实践(一)>交代完问题的背景和Mysql事务基础后,这一篇主要想介绍一下事务在Django中的使用以及实际应用给我们带来的效率提升. 首先 ...
- Mysql事务探索及其在Django中的实践(一)
前言 很早就有想开始写博客的想法,一方面是对自己近期所学知识的一些总结.沉淀,方便以后对过去的知识进行梳理.追溯,一方面也希望能通过博客来认识更多相同技术圈的朋友.所幸近期通过了博客园的申请,那么今天 ...
- 《Django By Example》第三章 中文 翻译 (个人学习,渣翻)
书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:第三章滚烫出炉,大家请不要吐槽文中 ...
- 《Django By Example》第二章 中文 翻译 (个人学习,渣翻)
书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:翻译完第一章后,发现翻译第二章的速 ...
- 《Django By Example》第一章 中文 翻译 (个人学习,渣翻)
书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:本人目前在杭州某家互联网公司工作, ...
- Django
一.Django 简介 Django 是一个由 Python 写成的开放源代码的 Web 应用框架.它最初是被开发来用于管理劳伦斯出版集团旗下的一些以新闻内容为主的网站的,即是 CMS(内容管理系统) ...
- Django admin定制化,User字段扩展[原创]
前言 参考上篇博文,我们利用了OneToOneField的方式使用了django自带的user,http://www.cnblogs.com/caseast/p/5909248.html , 但这么用 ...
随机推荐
- bat命令自用其(一)
每秒钟打印ping命令结果到指定文件: @echo off set /p ip=Input the IP required to monitor: :starts echo %date% %time% ...
- iOS开发之3D Touch
1.简介 3DTouch是在6s之后苹果的一项技术,只能在6s及其以上机型真机运行,Xcode的模拟器是不支持的. Quick Actions(点击icon的快捷方式) Peek&Pop(应用 ...
- python学习3—数据类型之整型、字符串和布尔值
python学习3-数据类型之整型.字符串和布尔值 数据类型 python3支持的数据类型共有6种: 1 Number 2 String 3 List 4 Tuple 5 Set 6 Dictiona ...
- 收藏的链接-English
What is the adverb for deposit? https://www.wordhippo.com/what-is/the-adverb-for/deposit.html
- 【POJ】2236 Wireless Network
题目链接:http://poj.org/problem?id=2236 题意:给你n台计算机的坐标.d是可通信的最大距离.有两个操作. 1.O p 表示修复计算机p. 2.S p q表示询问pq是否能 ...
- ie8以下不兼容h5新标签的解决方法
HTML5新添了一些语义化标签,他们能让代码语义化更直观易懂,有利于SEO优化.但是此HTML5新标签在IE6/IE7/IE8上并不能识别,需要进行JavaScript处理. 解决思路就是用js创建h ...
- shell 脚本999乘法表
99乘法表 vi st.sh 编辑一个脚本 chmod 777 st.sh 修改权限 注意调整空格,否则打印不出效果 执行脚本 ./st.sh 打印结果
- 【JZOJ6345】ZYB建围墙
description analysis 打表找规律,自认为样例给的提示很明显 容易想到最优方案是让家庭尽量先围成一个正六边形,剩下的在最外层绕一个圈 手推一波可以知道,如果正六边形有\(n\)层,剩 ...
- HashMap 什么时候进行扩容呢
HashMap扩容: 当HashMap中的元素越来越多的时候,碰撞的几率也就越来越高(因为数组的长度是固定的),所以为了提高查询的效率,就要对HashMap的数组进行扩容,数组扩容这个操作也会出现在A ...
- SQL Server DOC
{ https://docs.microsoft.com/zh-cn/sql/sql-server/index?view=sql-server-ver15 }