在Python的Django框架中实现Hacker News的一些功能_python

逐步指示

这是提供给更喜欢阅读的人的视频文本版本。我们将创建一个类似黑客新闻 或Reddit的社交新闻网站。它将被称为“钢铁传闻”,作为一个分享关于“钢铁侠”的有趣传闻和对其进行投票的地方。

屏幕录像第一部分的概述:

  •     目标
  •     虚拟环境- 从零开始!
  •     模型管理 - 梦想的工作 #78
  •     基本的模板
  •     通用视图 - 新闻列表视图和 新闻细节视图
  •     分页-免费!!

设置虚拟环境

    我们将用virtualenv 和 virtualenvwrapper来建立一个虚拟开发环境。首先请确认你已经安装了它们:

    

mkvirtualenv djangorocks

    我在屏幕录像中使用的是一个叫Xubuntu的变种Ubuntu系统。但你应该能够在其他的操作系统以最小的改变重复这些步骤。

    安装 Django (请确认你已经安装了pip ):
 

  pip install Django==1.5

    你也可以使用 Django 1.5.1. 这些方法和代码在最新的 Django 版本中没有测试过能否工作,所以最好按照本教程使用的版本来学习。

创建工程和应用

    创建一个名为steelrumors的工程:
 

复制代码 代码如下:

    cd ~/projects
    django-admin.py startproject steelrumors
    cd steelrumors
    chmod +x manage.py

    在你喜爱的编辑器中打开steelrumors/settings.py文件。定位和改变下列内容 (改变用粗体显示):
       

复制代码 代码如下:

'ENGINE': 'django.db.backends.sqlite3'
        'NAME': 'database.db',

        最后 INSTALLED_APPS = ( 'django.contrib.admin',

    接下来,修改steelrumors/urls.py,取消下列行的注释:
 
    

from django.contrib import admin
  admin.autodiscover()

  urlpatterns = patterns('',
    url(r'^admin/', include(admin.site.urls)),
  )

    同步创建管理对象并进入管理详细资料:

  

 ./manage.py syncdb

    打开一个新标签或一个新终端并保持服务器实例在运行(不要忘了在这个终端上发布可工作的djangorocks):
 

  ./manage.py runserver

    访问管理页 (一般是 http://127.0.0.1:8000/admin/) 并登录.

    创建链接应用:
 

  ./manage.py startapp links

    输入下面两个模型类到links/models.py文件中:
 
  

 from django.db import models
  from django.contrib.auth.models import User

  class Link(models.Model):
    title = models.CharField("Headline", max_length=100)
    submitter = models.ForeignKey(User)
    submitted_on = models.DateTimeField(auto_now_add=True)
    rank_score = models.FloatField(default=0.0)
    url = models.URLField("URL", max_length=250, blank=True)
    description = models.TextField(blank=True)

    def __unicode__(self):
      return self.title

  class Vote(models.Model):
    voter = models.ForeignKey(User)
    link = models.ForeignKey(Link)

    def __unicode__(self):
      return "%s upvoted %s" % (self.voter.username, self.link.title)

    建立相应的管理类。输入下面内容到 links/admin.py 中:
 
   

 from django.contrib import admin
  from .models import Link, Vote

  class LinkAdmin(admin.ModelAdmin): pass
  admin.site.register(Link, LinkAdmin)

  class VoteAdmin(admin.ModelAdmin): pass
  admin.site.register(Vote, VoteAdmin)

    输入下面内容到links/views.py:
 
  

 from django.views.generic import ListView
  from .models import Link, Vote

  class LinkListView(ListView):
    model = Link

  Insert following lines intosteelrumor/urls.py:

  from links.views import LinkListView
  ...
  urlpatterns = patterns('',
    url(r'^$', LinkListView.as_view(), name='home'),

    建立一个新的模板文件夹,在steelrumors/templates/links/link_list.html中输入下面内容:
 
    

<ol>
  {% for link in object_list %}
    <li>
    <a href="{{ link.url }}">
     <b>{{ link.title }}</b>
    </a>
    </li>
  {% endfor %}
  </ol>

    编辑settings.py,添加你的两个应用到INSTALLED_APPS = (的尾部:
  

  'links',
  'steelrumors',
  )

    同步建立链接对象,并在管理界面里输入一些数据:
  
 

  ./manage.py syncdb

 添加品牌

    建立一个通用基本模板steelrumors/templates/base.html:
 
   

 <html>
  <body>
  <h1>Steel Rumors</h1>

  {% block content %}
  {% endblock %}

  </body>
  </html>

    修改steelrumors/templates/links/link_list.html,用这种方式把原先代码包裹起来:

    


  {% extends "base.html" %}

  {% block content %}
  ...
  {% endblock %}

投票数模型管理器

    我们需要在我们的通用ListView中添加一个计票数。添加这些到 links/models.py:
 
 

  from django.db.models import Count

  class LinkVoteCountManager(models.Manager):
    def get_query_set(self):
      return super(LinkVoteCountManager, self).get_query_set().annotate(
        votes=Count('vote')).order_by('-votes')

  Insert these two lines into the Link class inlinks/models.py:

  class Link(models.Model):
  ...

    with_votes = LinkVoteCountManager()
    objects = models.Manager() #default manager

    编辑 links/views.py,添加这两行到LinkListView类中:
   
   

 class LinkListView(ListView):
  ...

    queryset = Link.with_votes.all()
    paginate_by = 3

狂欢(作弊)

您可以在django shell中用下面的行给随机的标题添加100个选票数:
 

$ ./manage.py shell
>>> from links.models import Link
>>> for i in xrange(100): Vote(link=Link.objects.order_by('?')[0],voter=a).save()

最终评论

或许你想知道这个网站的这个版本是否有用,我想说,它作为私人测试版是工作不错的。任何新用户都必须通过管理界面手动添加。如果想让他们登陆管理界面,他们必须是员工。员工可以通过手动创建投票对象来进行投票。

站点面向大众的部分仍能显示来自员工投票率最高的传闻。基于如何设计好的模板的问题,这个版本也可以用来获取对网站的设计和品牌的反馈。

总结完第一部分。想得到随后部分的更新,请在Twitter上粉我一个@arocks。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索python
python django框架、python web框架django、python的django框架、hacker news、vue hackernews 2.0,以便于您获取更多的相关知识。

时间: 2024-10-31 22:49:04

在Python的Django框架中实现Hacker News的一些功能_python的相关文章

Python的Django框架中settings文件的部署建议

这篇文章主要介绍了Python的Django框架中settings文件的部署建议,包括对local_settings的弊病的一些简单分析,需要的朋友可以参考下 django在一个项目的目录结构划分方面缺乏必要的规范,因此不同人的项目组织形式也千奇百怪,而且也很难说谁的做法就比较好.我根据自己的项目组织习惯,发布了一个项目dj-scaffold. 前些天在reddit上为我的项目dj-scaffold打了个"广告"(见:http://redd.it/kw5d4).不想评价甚糟,甚至差点被

在Python的Django框架中simple-todo工具的简单使用

  这篇文章主要介绍了在Python的Django框架中simple-todo工具的简单使用,该工具基于原web.py中的开源项目,需要的朋友可以参考下 缘起 simple-todo最早是web.py一个中文教程的例子.后来Uliweb的作者limodou 认为这个教程很不错,于是有了Uliweb版的simple-todo.接着又有了Bottle版和Flask版.这俨然成了一个FrameworksShow项目.既然是FrameworksShow, 那Django的总不应当缺了吧. simple-

Python的Django框架中TEMPLATES项的设置教程

  这篇文章主要介绍了Python的Django框架中TEMPLATES项的设置教程,主要针对Django1.8后的新特性,需要的朋友可以参考下 TEMPLATES Django 1.8的新特性 一个列表,包含所有在Django中使用的模板引擎的设置.列表中的每一项都是一个字典,包含某个引擎的选项. 以下是一个简单的设定,告诉Django模板引擎从已安装的应用程序(installed applications)的templates子目录中读取模板: ? 1 2 3 4 5 6 TEMPLATES

Python的Django框架中的templates设置

  这篇文章主要介绍了Python的Django框架中的TEMPLATES设置,主要讲述了Django1.8版本后的一些新特性,需要的朋友可以参考下 TEMPLATES Django 1.8的新特性 一个列表,包含所有在Django中使用的模板引擎的设置.列表中的每一项都是一个字典,包含某个引擎的选项. 以下是一个简单的设定,告诉Django模板引擎从已安装的应用程序(installed applications)的templates子目录中读取模板: ? 1 2 3 4 5 6 TEMPLAT

全面剖析Python的Django框架中的项目部署技巧第1/2页_python

项目开始时是一个关键时刻,选择会对项目产生长期的影响.有很多关于如何开始使用Django框架的教程,但很少讨论如何专业地使用Django,或如何使用行业公认的最佳做法来确保你的项目规模的持续增长.事前的筹划让你(和所有同事的生活)在走向将来时更容易. 文章结束时,你将有     一个全功能的Django 1.6项目     源代码受控的所有资源(使用Git或Mercurial)     自动回归和单元测试(使用unittest库)     一个独立于特定环境的安装项目(使用virtualenv)

给Python的Django框架下搭建的BLOG添加RSS功能的教程_python

前些天有位网友建议我在博客中添加RSS订阅功能,觉得挺好,所以自己抽空看了一下如何在Django中添加RSS功能,发现使用Django中的syndication feed framework很容易实现.     具体实现步骤和代码如下:     1.Feed类 # -*- coding: utf-8 -*- from django.conf import settings from django.contrib.syndication.views import Feed from django.

利用Python的Django框架中的ORM建立查询API_python

 摘要 在这篇文章里,我将以反模式的角度来直接讨论Django的低级ORM查询方法的使用.作为一种替代方式,我们需要在包含业务逻辑的模型层建立与特定领域相关的查询API,这些在Django中做起来不是非常容易,但通过深入地了解ORM的内容原理,我将告诉你一些简捷的方式来达到这个目的. 概览 当编写Django应用程序时,我们已经习惯通过添加方法到模型里以此达到封装业务逻辑并隐藏实现细节.这种方法看起来是非常的自然,而且实际上它也用在Django的内建应用中.   >>> from dja

Python的Django框架中的select_related函数对QuerySet 查询的优化_python

1. 实例的背景说明 假定一个个人信息系统,需要记录系统中各个人的故乡.居住地.以及到过的城市.数据库设计如下: Models.py 内容如下: from django.db import models class Province(models.Model): name = models.CharField(max_length=10) def __unicode__(self): return self.name class City(models.Model): name = models

在Python的Flask框架中使用日期和时间的教程_python

 时间戳的问题 我们的微博应用的一个忽略了很久的问题就是日间和日期的显示. 直到现在,我们在我们的User和Post对象中使用Python它自己的方式来渲染时间对象,但这并不是一个好的解决方案. 考虑下这样的例子.我正在写这篇文章,此时正是12月31号下午3:54.我的时区是PST(或者你们更习惯的:UTC-8). 在Python解释器中运行,我得到下面输出:   >>> from datetime import datetime >>> now = datetime.