Bạn thực sự phải cuộn phương pháp của riêng bạn để làm điều này, như JustLoren nói.
Đây là phương pháp tiện ích mở rộng mà tôi đã sử dụng. Nó là GateKiller tập lệnh được tạo thành một phương pháp mở rộng. Vì vậy, tín dụng đầy đủ cho anh ta. Bạn có thể dễ dàng thay đổi nó để tuy nhiên bạn muốn nó.
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";
}
Thú vị. Tôi không chắc chắn bạn sẽ nhận được bất kỳ câu trả lời nào ngoài "cuộn của riêng bạn" :) – JustLoren
Một trong những câu hỏi đầu tiên trên trang web này đã giải quyết vấn đề này: http://stackoverflow.com/questions/11/how- do-i-calculate-relative-time –
Và để biết cách đạt được điều này trong SQL (bạn có bao giờ muốn): http://stackoverflow.com/questions/50149/best-way-to-convert-datetime-to -n-giờ-trước-trong-sql – CraigTP