在.NET中以相对文本形式表示日期(例如今天、昨天、1周前)

9

有没有简单的函数可以在.NET中将日期转换为简单的日期相对字符串?

例如,14-Oct-09将显示为“今天”,13-Oct-09将显示为“昨天”,7-Oct-09将显示为“1周前”等。


有趣的看法。我不确定你会得到除了“自己动手做”之外的任何答案 :) - JustLoren
5
这个网站上最早的问题之一涉及到了这个问题:https://dev59.com/b3VD5IYBdhLWcg3wXamd - Fredrik Mörk
而要在 SQL 中实现这一点(如果您需要的话):https://dev59.com/8kXRa4cB1Zd3GeqPoxek - CraigTP
这个回答解决了你的问题吗?在C#中计算相对时间 - zcoop98
2个回答

9

正如JustLoren所说,您确实需要自己编写此方法。

这是我一直在使用的扩展方法。它是GateKiller脚本转换成的扩展方法。所有功劳归他。您可以轻松地根据自己的需求进行更改。

public static string ToTimeSinceString(this DateTime value)
{
    const int SECOND = 1;
    const int MINUTE = 60 * SECOND;
    const int HOUR = 60 * MINUTE;
    const int DAY = 24 * HOUR;
    const int MONTH = 30 * DAY;

    TimeSpan ts = new TimeSpan(DateTime.Now.Ticks - value.Ticks);
    double seconds = ts.TotalSeconds;

    // Less than one minute
    if (seconds < 1 * MINUTE)
        return ts.Seconds == 1 ? "one second ago" : ts.Seconds + " seconds ago";

    if (seconds < 60 * MINUTE)
        return ts.Minutes + " minutes ago";

    if (seconds < 120 * MINUTE)
        return "an hour ago";

    if (seconds < 24 * HOUR)
        return ts.Hours + " hours ago";

    if (seconds < 48 * HOUR)
        return "yesterday";

    if (seconds < 30 * DAY)
        return ts.Days + " days ago";

    if (seconds < 12 * MONTH) {
        int months = Convert.ToInt32(Math.Floor((double)ts.Days / 30));
        return months <= 1 ? "one month ago" : months + " months ago";
    }

    int years = Convert.ToInt32(Math.Floor((double)ts.Days / 365));
    return years <= 1 ? "one year ago" : years + " years ago";
}

这似乎直接来自我在问题评论中链接的被接受答案;o) - Fredrik Mörk
非常抱歉。我忘记了它来自哪里。已经为答案添加了署名。 - aolde
假设您的数据库存储的是UTC时间,为了符合最佳实践,您应该使用DateTime.UtcNow.Ticks而不是.Now - James Reategui

6
像这样的扩展方法吗?
public static string Stringfy(this DateTime date)
{
    if ((DateTime.Now - date.Date).TotalDays == 0)
        return "Today";

    if ((DateTime.Now - date.Date).TotalDays == 1)
        return "Yesterday";

    // ...

    return "A long time ago, in a galaxy far far away...";
}

TotalDays 不是 double 类型吗?也许需要使用 Truncate 来获取整天,甚至可以使用 DateTime.Now.Date 而不是 DateTime.Now。 - Darren

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接