5

是否有“逆转人性化”时代的功能?

例如,给定(字符串):

  • '1 分钟前'
  • '7 小时前'
  • '5天前'
  • '2个月前'

可以返回(为伪代码道歉):

  • datetime.now() - timedelta(1 分钟),准确度(60 秒)
  • datetime.now() - timedelta(7 小时),准确度(1 小时)
  • datetime.now() - timedelta(5 天),准确度(1 天)
  • datetime.now() - timedelta(2 个月),准确度(1 个月)
4

2 回答 2

2

我一直在使用parsedatetime,它对我来说效果很好。主页列出了它可以处理的一些格式,例如:

  • 5分钟内
  • 5分钟后
  • 中午前 2 小时
  • 明天起2天

我发现的主要缺点是它没有时区感。

如果它有价值,这是我使用的包装函数,datetime无论输入字符串是相对的(如所有示例)还是固定的,它总是返回一个对象:

def parse_datetime(datetime_string):
    datetime_parser = parsedatetime.Calendar(parsedatetime_consts.Constants())
    timestamp = datetime_parser.parse(datetime_string)
    if len(timestamp) == 2:
        if timestamp[1] == 0:
            raise ValueError(u'Failed to parse datetime: %s' % datetime_string)
        timestamp = timestamp[0]
    return datetime.fromtimestamp(time.mktime(timestamp))
于 2011-01-29T21:50:12.370 回答
1

你能不能自己写一个简单的实现,例如:

import datetime

def parsedatetime(str_val):

  parts = str_val.split(' ')

  if len(parts) != 3 and parts[2] != 'ago':
     raise Exception("can't parse %s" % str_val)

  try:
     interval = int(parts[0])
  except ValueError,e :
     raise Exception("can't parse %s" % str_val)

  desc = parts[1]

  if 'second' in desc:
     td = datetime.timedelta(seconds=interval)
  elif 'minute' in desc:
     td = datetime.timedelta(minutes=interval)
  elif 'hour' in desc:
     td = datetime.timedelta(minutes=interval*60)
  elif 'day' in desc:
     td = datetime.timedelta(days=interval)
  else:
     raise Exception("cant parse %s" % str_val)

   answer = datetime.datetime.now - td
   return answer

输入看起来并没有那么多样。

于 2011-02-16T22:25:08.910 回答