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


Posted in Python onApril 17, 2015

逐步指示

这是提供给更喜欢阅读的人的视频文本版本。我们将创建一个类似黑客新闻 或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中xrange用法分析
Apr 15 Python
在centos7中分布式部署pyspider
May 03 Python
Python 网页解析HTMLParse的实例详解
Aug 10 Python
基于python时间处理方法(详解)
Aug 14 Python
Python pymongo模块用法示例
Mar 31 Python
Python实现模拟登录网易邮箱的方法示例
Jul 05 Python
Python面向对象程序设计构造函数和析构函数用法分析
Apr 12 Python
Python 异常的捕获、异常的传递与主动抛出异常操作示例
Sep 23 Python
python和js交互调用的方法
Jun 23 Python
详解win10下pytorch-gpu安装以及CUDA详细安装过程
Jan 28 Python
matplotlib之属性组合包(cycler)的使用
Feb 24 Python
教你怎么用Python selenium操作浏览器对象的基础API
Jun 23 Python
由Python运算π的值深入Python中科学计算的实现
Apr 17 #Python
在Python中实现贪婪排名算法的教程
Apr 17 #Python
在Linux下调试Python代码的各种方法
Apr 17 #Python
Python脚本在Appium库上对移动应用实现自动化测试
Apr 17 #Python
Python中生成器和yield语句的用法详解
Apr 17 #Python
使用Python脚本在Linux下实现部分Bash Shell的教程
Apr 17 #Python
使用Python的Scrapy框架编写web爬虫的简单示例
Apr 17 #Python
You might like
咖啡常见的种类
2021/03/03 新手入门
php格式化金额函数分享
2015/02/02 PHP
深入解析WordPress中加载模板的get_template_part函数
2016/01/11 PHP
编写PHP程序检查字符串中的中文字符个数的实例分享
2016/03/17 PHP
thinkphp5.1 文件引入路径问题及注意事项
2018/06/13 PHP
Django 标签筛选的实现代码(一对多、多对多)
2018/09/05 PHP
Javascript实例教程(19) 使用HoTMetal(2)
2006/12/23 Javascript
InnerHtml和InnerText的区别分析
2009/03/13 Javascript
js escape,unescape解决中文乱码问题的方法
2010/05/26 Javascript
javascript延时加载之defer测试
2012/12/28 Javascript
javascript 表格内容排序 简单操作示例代码
2014/01/03 Javascript
JS网页图片按比例自适应缩放实现方法
2014/01/15 Javascript
mvc中form表单提交的三种方式(推荐)
2016/08/10 Javascript
JS点击某个图标或按钮弹出文件选择框的实现代码
2016/09/27 Javascript
JavaScript 闭包机制详解及实例代码
2016/10/10 Javascript
angular2倒计时组件使用详解
2017/01/12 Javascript
Vue-Cli 3.0 中配置高德地图的两种方式
2019/06/19 Javascript
解决layer.confirm选择完之后消息框不消失的问题
2019/09/16 Javascript
解决Vue在Tomcat8下部署页面不加载的问题
2019/11/12 Javascript
跟老齐学Python之dict()的操作方法
2014/09/24 Python
浅谈Python中数据解析
2015/05/05 Python
对python实现模板生成脚本的方法详解
2019/01/30 Python
python3爬虫学习之数据存储txt的案例详解
2019/04/24 Python
Python读取VOC中的xml目标框实例
2020/03/10 Python
地理科学专业毕业生求职信
2013/10/15 职场文书
应届生服务员求职信
2013/10/31 职场文书
计算机通信专业推荐信
2014/02/22 职场文书
经济管理毕业生求职信
2014/03/15 职场文书
幼儿园毕业典礼主持词
2014/03/21 职场文书
职工代表大会主持词
2014/04/01 职场文书
法院执行局工作总结
2015/08/11 职场文书
敬业奉献模范事迹材料(2016精选版)
2016/02/26 职场文书
创业计划书之暑假培训班
2019/11/09 职场文书
MYSQL 无法识别中文的永久解决方法
2021/06/03 MySQL
MySQL 百万级数据的4种查询优化方式
2021/06/07 MySQL
win10频率超出范围怎么办?win10老显示超出工作频率范围的解决方法
2022/07/07 数码科技