1

このように軍事時間を変換する方法は?

 07:03    -->   07:30
 06:45    -->   07:00
 07:36    -->   08:00

 19:15    -->   19:30
 18:35    -->   19:00
 19:35    -->   20:00

基本的には、時間が30分間隔の場合、残りの分を合計して全体の時間になります。

私のデータベースでは、次のように時間を比較する必要があります。

function check_range($get_shift, $date, $time, $id, $mode) {
    $sql = "SELECT * FROM tbl_employee WHERE id = '$id'";
    $result = mysql_query($sql);
    $row_check_range = mysql_fetch_assoc($result);
    $getShift = $row_check_range['shift'];

    $sql2 = "SELECT * FROM tbl_shift WHERE shift = '$getShift'";
    $result2 = mysql_query($sql2);
    $row_check_range2 = mysql_fetch_assoc($result2);
    $getTimeShift = $row_check_range2['timeIn'];

    $actual_time_in_mode = explode(':', $time); //split time into (e.g 07, 11)
    if ($mode == 'AM') {
        $time_in_actual = $actual_time_in_mode[0];
    } else {
        $time_in_actual = $actual_time_in_mode[0];
        $time_shift = explode(':', $getTimeShift);
        $getTimeShift = $time_shift[0] + 12; //convert to military time
    }

    $getTimeShift = mktime($getTimeShift);
    $actual_in_mode = mktime($time);

    if ($actual_in_mode > $getTimeShift) // LATE
    {
        return $date.' '.$time_in_actual.':30:00';
    } else {
        $time_in_actual += 1;
        return $date.' '.$time_in_actual.':00:00';
    }
}
4

3 に答える 3

0

30 分を追加してから、数値を最も近い:30またはに切り捨て:00ます。

于 2013-08-03T01:52:40.430 に答える