如何将此Python代码转换为ColdFusion代码?

时间:2012-02-03 13:01:28

标签: python sql coldfusion railo

我希望构建一个使用Reddit(开源)算法的Web应用程序。

我计划随着时间推移调整它,但现在我认为使用他们的排名系统将是一个良好的开端。

我读了一篇关于这个算法的博客文章,这个例子是用Python编写的。如何将其转换为在ColdFusion中使用?如果更方便,可以在CFC中使用额外的奖励积分吗?

代码:

#Rewritten code from /r2/r2/lib/db/_sorts.pyx

from datetime import datetime, timedelta
from math import log

epoch = datetime(1970, 1, 1)

def epoch_seconds(date):
    """Returns the number of seconds from the epoch to date."""
    td = date - epoch
    return td.days * 86400 + td.seconds + (float(td.microseconds) / 1000000)

def score(ups, downs):
    return ups - downs

def hot(ups, downs, date):
    """The hot formula. Should match the equivalent function in postgres."""
    s = score(ups, downs)
    order = log(max(abs(s), 1), 10)
    sign = 1 if s > 0 else -1 if s < 0 else 0
    seconds = epoch_seconds(date) - 1134028003
    return round(order + sign * seconds / 45000, 7) 

讨论此代码的博客文章: http://amix.dk/blog/post/19588

期待听到一些想法和例子。

非常感谢! 迈克尔。

另外,作为一个额外的问题;在数据集已被收集之后,是否可以通过SQL查询或ColdFusion 中的某种排序更好地执行此代码?我选择的数据库是MySQL。

更新 刚刚在这里找到了另一个与我所问的相关的问题......我认为这有帮助。 How are Reddit and Hacker News ranking algorithms used?

1 个答案:

答案 0 :(得分:6)

大多数代码只是来自任何编程语言的标准代码

例如,在ColdFusion

中获取特定日期以来的秒数非常简单
<cfset seconds = dateDiff('s', now(), createDate(1970, 1, 1)) />

不确定你坚持使用哪些,但它的所有简单。我看到的每个功能都有一个ColdFusion版本,而且不想让别人为你重写它,我建议你尝试这样做,并询问你是否遇到了问题。