11

PHPにこのコードがあります

function nicetime($date)
{
date_default_timezone_set("Asia/Taipei");
if(empty($date)) {
    return "No date provided";
}

$periods         = array("second", "minute", "hour", "day", "week", "month", "year", "decade");
$lengths         = array("60","60","24","7","4.35","12","10");

$now             = time();
$unix_date         = strtotime($date);

   // check validity of date
if(empty($unix_date)) {    
    return "Bad date";
}

// is it future date or past date
if($now > $unix_date) {    
    $difference     = $now - $unix_date;
    $tense         = "ago";

} else {
    $difference     = $unix_date - $now;
    $tense         = "from now";
}

for($j = 0; $difference >= $lengths[$j] && $j < count($lengths)-1; $j++) {
    $difference /= $lengths[$j];
}

$difference = round($difference);

if($difference != 1) {
    $periods[$j].= "s";
}

return "$difference $periods[$j] {$tense}";
}

でも今は同じことをしたいのですが、今回はAndroidで。文字列 mytime がデータベースからの SQL 形式であるため、問題が発生しています。

String mytime = pref.getString("announcementtime" + count, null);

mytime の出力:

2013-08-31 15:55:22

私はそれをに変換したい:

23 minutes ago //something like this

デフォルトのタイムゾーンと DateTime = Now に注意してください

4

3 に答える 3

35

そのすべてがDateUtilsクラスにあります。

CharSequence getRelativeTimeSpanString (long time, long now, long minResolution);

次のような形式で時間と現在の差を示します。

54秒前。

日付文字列を使用するには、最初にそれをエポック時間に変換する必要があります。

String mytime = pref.getString("announcementtime" + count, null); 

// it comes out like this 2013-08-31 15:55:22 so adjust the date format
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date date = df.parse(str);
long epoch = date.getTime();

String timePassedString = getRelativeTimeSpanString (epoch, System.currentTimeMillis(), DateUtils.SECOND_IN_MILLIS);
于 2013-09-04T06:50:50.883 に答える
4

Github には、まさにこの目的のための優れたライブラリがあります: https://github.com/curioustechizen/android-ago

于 2013-09-04T06:47:36.987 に答える