wake-up-neo.com

Konvertieren Sie das in Sekunden angegebene Zeitintervall in eine für den Menschen besser lesbare Form

Ich brauche ein Code-Snippet, um die durch die Anzahl der Sekunden angegebene Zeit in eine vom Menschen lesbare Form zu konvertieren. Die Funktion sollte eine Zahl erhalten und eine Zeichenfolge wie folgt ausgeben:

34 seconds 
12 minutes 
4 hours 
5 days 
4 months
1 year

Keine Formatierung erforderlich, hartcodiertes Format wird verwendet.

56
Dan

Mit Hilfe von Royi haben wir Code, der das Zeitintervall in einer für Menschen lesbaren Form ausgibt :

function millisecondsToStr (milliseconds) {
    // TIP: to find current time in milliseconds, use:
    // var  current_time_milliseconds = new Date().getTime();

    function numberEnding (number) {
        return (number > 1) ? 's' : '';
    }

    var temp = Math.floor(milliseconds / 1000);
    var years = Math.floor(temp / 31536000);
    if (years) {
        return years + ' year' + numberEnding(years);
    }
    //TODO: Months! Maybe weeks? 
    var days = Math.floor((temp %= 31536000) / 86400);
    if (days) {
        return days + ' day' + numberEnding(days);
    }
    var hours = Math.floor((temp %= 86400) / 3600);
    if (hours) {
        return hours + ' hour' + numberEnding(hours);
    }
    var minutes = Math.floor((temp %= 3600) / 60);
    if (minutes) {
        return minutes + ' minute' + numberEnding(minutes);
    }
    var seconds = temp % 60;
    if (seconds) {
        return seconds + ' second' + numberEnding(seconds);
    }
    return 'less than a second'; //'just now' //or other string you like;
}
61
Dan
 function secondsToString(seconds)
{
var numyears = Math.floor(seconds / 31536000);
var numdays = Math.floor((seconds % 31536000) / 86400); 
var numhours = Math.floor(((seconds % 31536000) % 86400) / 3600);
var numminutes = Math.floor((((seconds % 31536000) % 86400) % 3600) / 60);
var numseconds = (((seconds % 31536000) % 86400) % 3600) % 60;
return numyears + " years " +  numdays + " days " + numhours + " hours " + numminutes + " minutes " + numseconds + " seconds";

}
69
Royi Namir

Wenn Sie an einer vorhandenen Javascript-Bibliothek interessiert sind, die den Job sehr gut macht, sollten Sie moment.js überprüfen.

Genauer gesagt, ist das relevante moment.js-Stück für Ihre Frage dauer

Hier einige Beispiele, wie Sie diese Aufgabe zur Erreichung Ihrer Aufgabe nutzen können:

var duration = moment.duration(31536000);

// Using the built-in humanize function:
console.log(duration.humanize());   // Output: "9 hours"
console.log(duration.humanize(true));   // Output: "in 9 hours"

moment.js hat eine integrierte Unterstützung für mehr als 50 menschliche Sprachen. Wenn Sie also die humanize()-Methode verwenden, erhalten Sie die kostenlose Unterstützung in mehreren Sprachen.

Wenn Sie die genauen Zeitangaben anzeigen möchten, können Sie das moment-precision-range -Plug-In für moment.js nutzen, das genau für diesen Zweck erstellt wurde:

console.log(moment.preciseDiff(0, 39240754000);
// Output: 1 year 2 months 30 days 5 hours 12 minutes 34 seconds

Zu beachten ist, dass Moment.js momentan keine Wochen/Tage (in Woche) für das Dauerobjekt unterstützt.

Hoffe das hilft!

41
urish

Versuchen Sie folgendes:

seconds = ~~(milliseconds / 1000);
minutes = ~~(seconds / 60);
hours = ~~(minutes / 60);
days = ~~(hours / 24);
weeks = ~~(days / 7);
year = ~~(days / 365);

Hinweis:

  • Ein gewöhnliches Jahr hat 365 Tage. Ein Schaltjahr hat 366 Tage. Sie müssen also überprüfen, ob dies ein Problem für Sie ist.
  • Ähnliches Problem bei der Sommerzeit. Einige Tage haben 23 und 25 Stunden, wenn sich die Zeit ändert.

Fazit: Dies ist ein unhöflicher, aber kleiner und einfacher Ausschnitt :)

16
reporter

Hat einen Schwung gemacht, basierend auf @ Royis Antwort:

/**
 * Translates seconds into human readable format of seconds, minutes, hours, days, and years
 * 
 * @param  {number} seconds The number of seconds to be processed
 * @return {string}         The phrase describing the the amount of time
 */
function forHumans ( seconds ) {
    var levels = [
        [Math.floor(seconds / 31536000), 'years'],
        [Math.floor((seconds % 31536000) / 86400), 'days'],
        [Math.floor(((seconds % 31536000) % 86400) / 3600), 'hours'],
        [Math.floor((((seconds % 31536000) % 86400) % 3600) / 60), 'minutes'],
        [(((seconds % 31536000) % 86400) % 3600) % 60, 'seconds'],
    ];
    var returntext = '';

    for (var i = 0, max = levels.length; i < max; i++) {
        if ( levels[i][0] === 0 ) continue;
        returntext += ' ' + levels[i][0] + ' ' + (levels[i][0] === 1 ? levels[i][1].substr(0, levels[i][1].length-1): levels[i][1]);
    };
    return returntext.trim();
}

Das Schöne an mir ist, dass es keine sich wiederholenden ifs gibt und dass Sie zum Beispiel nicht 0 Jahre 0 Tage 30 Minuten 1 Sekunde erhalten.

Zum Beispiel:

forHumans(60) gibt 1 minute aus

forHumans(3600) gibt 1 hour aus

und forHumans(13559879) gibt 156 days 22 hours 37 minutes 59 seconds aus

14
Martin

Viel einfacher und lesbarer.

milliseconds = 12345678;
mydate=new Date(milliseconds);
humandate=mydate.getUTCHours()+" hours, "+mydate.getUTCMinutes()+" minutes and "+mydate.getUTCSeconds()+" second(s)";

Was gibt:

"3 Stunden, 25 Minuten und 45 Sekunden"

13
Zibri
millisToTime = function(ms){

    x = ms / 1000;
    seconds = Math.round(x % 60);
    x /= 60;
    minutes = Math.round(x % 60);
    x /= 60;
    hours = Math.round(x % 24);
    x /= 24;
    days = Math.round(x);

    return {"Days" : days, "Hours" : hours, "Minutes" : minutes, "Seconds" : seconds};
}

Dies dauert Millisekunden als int und gibt Ihnen ein JSON-Objekt, das alle Informationen enthält, die Sie benötigen

13
galv

Zeit in Millisekunden in ein vom Menschen lesbares Format konvertieren.

 function timeConversion(millisec) {

        var seconds = (millisec / 1000).toFixed(1);

        var minutes = (millisec / (1000 * 60)).toFixed(1);

        var hours = (millisec / (1000 * 60 * 60)).toFixed(1);

        var days = (millisec / (1000 * 60 * 60 * 24)).toFixed(1);

        if (seconds < 60) {
            return seconds + " Sec";
        } else if (minutes < 60) {
            return minutes + " Min";
        } else if (hours < 24) {
            return hours + " Hrs";
        } else {
            return days + " Days"
        }
    }

 "Out Put Sample"

3
Nofi
function millisecondsToString(milliseconds) {
    var oneHour = 3600000;
    var oneMinute = 60000;
    var oneSecond = 1000;
    var seconds = 0;
    var minutes = 0;
    var hours = 0;
    var result;

    if (milliseconds >= oneHour) {
        hours = Math.floor(milliseconds / oneHour);
    }

    milliseconds = hours > 0 ? (milliseconds - hours * oneHour) : milliseconds;

    if (milliseconds >= oneMinute) {
        minutes = Math.floor(milliseconds / oneMinute);
    }

    milliseconds = minutes > 0 ? (milliseconds - minutes * oneMinute) : milliseconds;

    if (milliseconds >= oneSecond) {
        seconds = Math.floor(milliseconds / oneSecond);
    }

    milliseconds = seconds > 0 ? (milliseconds - seconds * oneSecond) : milliseconds;

    if (hours > 0) {
        result = (hours > 9 ? hours : "0" + hours) + ":";
    } else {
        result = "00:";
    }

    if (minutes > 0) {
        result += (minutes > 9 ? minutes : "0" + minutes) + ":";
    } else {
        result += "00:";
    }

    if (seconds > 0) {
        result += (seconds > 9 ? seconds : "0" + seconds) + ":";
    } else {
        result += "00:";
    }

    if (milliseconds > 0) {
        result += (milliseconds > 9 ? milliseconds : "0" + milliseconds);
    } else {
        result += "00";
    }

    return result;
}
3
Obaluaiyê

Danke an @Dan/@ Royi für die Logik. Die Implementierung erstellt jedoch keine Zeitzeichenfolge wie XX Tage, XX Minuten. Ich habe ihren Code ein wenig angepasst:

function millisecondsToStr( milliseconds ) {
    let temp = milliseconds / 1000;
    const years = Math.floor( temp / 31536000 ),
          days = Math.floor( ( temp %= 31536000 ) / 86400 ),
          hours = Math.floor( ( temp %= 86400 ) / 3600 ),
          minutes = Math.floor( ( temp %= 3600 ) / 60 ),
          seconds = temp % 60;

    if ( days || hours || seconds || minutes ) {
      return ( years ? years + "y " : "" ) +
      ( days ? days + "d " : "" ) +
      ( hours ? hours + "h " : ""  ) +
      ( minutes ? minutes + "m " : "" ) +
      Number.parseFloat( seconds ).toFixed( 2 ) + "s";
    }

    return "< 1s";
}

Wenn man es läuft

console.log("=", millisecondsToStr( 1540545689739 - 1540545684368 ));
console.log("=", millisecondsToStr( 351338536000 ));

Die Ergebnisse sehen wie folgt aus:

= 5.37s
= 11y 51d 10h 2m 16.00s
1
Dmitry Sheiko

Diese Funktion gibt Sekunden in diesem Format aus: 11h 22m, 1y 244d, 42m 4s usw. Legen Sie die maximale Variable so fest, dass beliebig viele Bezeichner angezeigt werden.

function secondsToString (seconds) {

var years = Math.floor(seconds / 31536000);
var max =2;
var current = 0;
var str = "";
if (years && current<max) {
    str+= years + 'y ';
    current++;
}
var days = Math.floor((seconds %= 31536000) / 86400);
if (days && current<max) {
    str+= days + 'd ';
    current++;
}
var hours = Math.floor((seconds %= 86400) / 3600);
if (hours && current<max) {
    str+= hours + 'h ';
    current++;
}
var minutes = Math.floor((seconds %= 3600) / 60);
if (minutes && current<max) {
    str+= minutes + 'm ';
    current++;
}
var seconds = seconds % 60;
if (seconds && current<max) {
    str+= seconds + 's ';
    current++;
}

return str;
}
1
Kiran Kumar

Mit der Hilfe von Dan antwortete ich darauf, wenn Sie die Differenz zwischen der nacherstellten Zeit (von DB sollte als UTC abgerufen werden sollen) und der Systemzeit des Benutzers berechnen und ihnen die verstrichene Zeit anzeigen, die Sie verwenden könnten unterhalb der Funktion

function dateToStr(input_date) {
  input_date= input_date+" UTC";
  // convert times in milliseconds
  var input_time_in_ms = new Date(input_date).getTime();
  var current_time_in_ms = new Date().getTime();
  var elapsed_time = current_time_in_ms - input_time_in_ms;

  function numberEnding (number) {
      return (number > 1) ? 's' : '';
  }

  var temp = Math.floor(elapsed_time / 1000);
  var years = Math.floor(temp / 31536000);
  if (years) {
      return years + ' year' + numberEnding(years);
  }
  //TODO: Months! Maybe weeks? 
  var days = Math.floor((temp %= 31536000) / 86400);
  if (days) {
      return days + ' day' + numberEnding(days);
  }
  var hours = Math.floor((temp %= 86400) / 3600);
  if (hours) {
      return hours + ' hour' + numberEnding(hours);
  }
  var minutes = Math.floor((temp %= 3600) / 60);
  if (minutes) {
      return minutes + ' minute' + numberEnding(minutes);
  }
  var seconds = temp % 60;
  if (seconds) {
      return seconds + ' second' + numberEnding(seconds);
  }
  return 'less than a second'; //'just now' //or other string you like;
}

zB: Verwendung 

var str = dateToStr('2014-10-05 15:22:16');
1
santoshthota

Um nur das anzuzeigen, was Sie brauchen, und nicht Tag 0, Stunden 0 ...

formatTime = function(time) {
        var ret = time % 1000 + ' ms';
        time = Math.floor(time / 1000);
        if (time !== 0) {
            ret = time % 60 + "s "+ret;
            time = Math.floor(time / 60);
            if (time !== 0) {
                ret = time % 60 + "min "+ret;
                time = Math.floor(time / 60);
                if (time !== 0) {
                    ret = time % 60 + "h "+ret;
                     ...
                }
            }           
        }
        return ret;
    };
1
Goofyrocks

Ich habe eine der anderen Antworten ein wenig bereinigt und liefert die Zeichenfolgen von Nice vor 10 Sekunden:

function msago (ms) {
    function suffix (number) { return ((number > 1) ? 's' : '') + ' ago'; }
    var temp = ms / 1000;
    var years = Math.floor(temp / 31536000);
    if (years) return years + ' year' + suffix(years);
    var days = Math.floor((temp %= 31536000) / 86400);
    if (days) return days + ' day' + suffix(days);
    var hours = Math.floor((temp %= 86400) / 3600);
    if (hours) return hours + ' hour' + suffix(hours);
    var minutes = Math.floor((temp %= 3600) / 60);
    if (minutes) return minutes + ' minute' + suffix(minutes);
    var seconds = Math.floor(temp % 60);
    if (seconds) return seconds + ' second' + suffix(seconds);
    return 'less then a second ago';
};
0
Adrian Seeley

Dies ist eine Lösung. Später können Sie nach ":" aufteilen und die Werte des Arrays übernehmen

 /**
 * Converts milliseconds to human readeable language separated by ":"
 * Example: 190980000 --> 2:05:3 --> 2days 5hours 3min
 */
function dhm(t){
    var cd = 24 * 60 * 60 * 1000,
        ch = 60 * 60 * 1000,
        d = Math.floor(t / cd),
        h = '0' + Math.floor( (t - d * cd) / ch),
        m = '0' + Math.round( (t - d * cd - h * ch) / 60000);
    return [d, h.substr(-2), m.substr(-2)].join(':');
}

//Example
var delay = 190980000;                   
var fullTime = dhm(delay);
console.log(fullTime);
0
ssamuel68

Nach einem ähnlichen Ansatz zu @Dan habe ich den Code von @Royi Namir geändert, um einen String mit Kommas und und auszugeben:

secondsToString = function(seconds) {
    var numdays, numhours, nummilli, numminutes, numseconds, numyears, res;
    numyears = Math.floor(seconds / 31536000);
    numdays = Math.floor(seconds % 31536000 / 86400);
    numhours = Math.floor(seconds % 31536000 % 86400 / 3600);
    numminutes = Math.floor(seconds % 31536000 % 86400 % 3600 / 60);
    numseconds = seconds % 31536000 % 86400 % 3600 % 60;
    nummilli = seconds % 1.0;
    res = [];
    if (numyears > 0) {
        res.Push(numyears + " years");
    }
    if (numdays > 0) {
        res.Push(numdays + " days");
    }
    if (numhours > 0) {
        res.Push(numhours + " hours");
    }
    if (numminutes > 0) {
        res.Push(numminutes + " minutes");
    }
    if (numseconds > 0) {
        res.Push(numminutes + " seconds");
    }
    if (nummilli > 0) {
        res.Push(nummilli + " milliseconds");
    }
    return [res.slice(0, -1).join(", "), res.slice(-1)[0]].join(res.length > 1 ? " and " : "");
};

Es hat keine Periode, so dass man danach Sätze hinzufügen kann, wie hier:

perform: function(msg, custom, conn) {
    var remTimeLoop;
    remTimeLoop = function(time) {
        if (time !== +custom[0]) {
            msg.reply((secondsToString(time)) + " remaining!");
        }
        if (time > 15) {
            return setTimeout((function() {
                return remTimeLoop(time / 2);
            }), time / 2);
        }
    };
    // ...
    remTimeLoop(+custom[0]);
}

Dabei ist custom[0] die gesamte Wartezeit; Die Zeit wird weiterhin durch 2 geteilt, die verbleibende Zeit bis zum Ende des Timers wird gewarnt und die Warnung beendet, sobald die Zeit unter 15 Sekunden liegt.

0
Gustavo6046

Ich bin ein großer Fan von Objekten, also habe ich dies aus https://metacpan.org/pod/Time::Seconds erstellt.

Verwendungszweck:

var human_readable = new TimeSeconds(986543).pretty(); // 11 days, 10 hours, 2 minutes, 23 seconds

;(function(w) {
  var interval = {
    second: 1,
    minute: 60,
    hour: 3600,
    day: 86400,
    week: 604800,
    month: 2629744, // year / 12
    year: 31556930 // 365.24225 days
  };

  var TimeSeconds = function(seconds) { this.val = seconds; };

  TimeSeconds.prototype.seconds = function() { return parseInt(this.val); };
  TimeSeconds.prototype.minutes = function() { return parseInt(this.val / interval.minute); };
  TimeSeconds.prototype.hours = function() { return parseInt(this.val / interval.hour); };
  TimeSeconds.prototype.days = function() { return parseInt(this.val / interval.day); };
  TimeSeconds.prototype.weeks = function() { return parseInt(this.val / interval.week); };
  TimeSeconds.prototype.months = function() { return parseInt(this.val / interval.month); };
  TimeSeconds.prototype.years = function() { return parseInt(this.val / interval.year); };

  TimeSeconds.prototype.pretty = function(chunks) {
    var val = this.val;
    var str = [];

    if(!chunks) chunks = ['day', 'hour', 'minute', 'second'];

    while(chunks.length) {
      var i = chunks.shift();
      var x = parseInt(val / interval[i]);
      if(!x && chunks.length) continue;
      val -= interval[i] * x;
      str.Push(x + ' ' + (x == 1 ? i : i + 's'));
    }

    return str.join(', ').replace(/^-/, 'minus ');
  };

  w.TimeSeconds = TimeSeconds;
})(window);
0

Wenn Sie nur Chrome 71 (derzeit Beta) unterstützen müssen, gibt es die Intl.RelativeTimeFormat-API.

Ein Beispiel aus dem Vorschlag:

let rtf = new Intl.RelativeTimeFormat ("en");

rtf.format (-1, "Tag");

'gestern'

Und es gibt noch viel mehr in diesem Blogbeitrag und in dem Vorschlag selbst .

0
Sam Zagrobelny