Advanced PHP library for parsing, formatting, converting, and humanizing time durations.
Supports intuitive input formats like 1h 30m, 01:30:00, or 5400 and provides custom formatting, JSON serialization, and accurate conversion to seconds and minutes.
🛠️ Built as an enhanced and modernized alternative to kevinkhill/php-duration, offering expanded feature support, token-based formatting, custom hours-per-day handling, and complete PHPUnit test coverage.
- Flexible input support: parse durations from strings, numbers, or colon-formatted time
- Conversion to seconds, minutes, arrays, strings, and JSON
- Custom formatting with tokens (d,hh,mm,ss, etc.)
- Support for days with customizable hoursPerDay
- Human-readable output (1h 30m)
- Chainable and reusable instance
- Implements JsonSerializableandStringable
- Fully tested with 100% PHPUnit coverage (61 tests, 134 assertions)
Install via Composer:
composer require demirkaric/php-duration-formatteruse Demirk\PhpDurationFormatter\TimeDuration;
$duration = new TimeDuration('1h 42m 30s');
echo $duration->toSeconds();      // 6150.0
echo $duration->toMinutes();      // 102.5
echo $duration->humanize();       // "1h 42m 30s"
echo $duration->format();         // "01:42:30" (default format)
echo (string) $duration;          // "01:42:30"
echo json_encode($duration);      // {"seconds":6150,"values":{"days":0,"hours":1,"minutes":42,"seconds":30},"formatted":"01:42:30","humanized":"1h 42m 30s"}- "1h 30m"
- "1d 4h 5m 2.5s"
- "01:30"or- "01:30:45"
- 3600or- 3661.5
- "2d"
Use format(string $pattern) to generate custom formatted strings.
| Token | Meaning | Example | 
|---|---|---|
| d | Days (non-padded) | 1 | 
| dd | Days (zero-padded) | 01 | 
| h | Hours (non-padded) | 2 | 
| hh | Hours (zero-padded) | 02 | 
| H | Total hours (including days) | 26 | 
| HH | Total hours (zero-padded) | 26 | 
| m | Minutes | 5 | 
| mm | Minutes (zero-padded) | 05 | 
| s | Seconds | 4.5 | 
| ss | Seconds (zero-padded) | 04.5 | 
| S | Rounded seconds | 4 | 
| SS | Rounded seconds (zero-padded) | 04 | 
$duration = new TimeDuration('1d 2h 5m 30s');
echo $duration->format('dd hh:mm:ss'); // 01 02:05:30
echo $duration->format('H:mm');        // 26:05
⚠️ format()will throw an exception if bothdandHare used together (conflict between relative and absolute hours).
$duration->toSeconds();                // float/int
$duration->toSeconds('1h 5s');         // pass string directly
$duration->toMinutes();                // in float
$duration->toMinutes(null, 0);         // rounded to int
$duration->toMinutes(null, 2);         // rounded to 2 decimal places$duration = new TimeDuration('2d 3h 15m');
echo $duration->humanize(); // "2d 3h 15m"This library is tested with PHPUnit:
- ✅ Covers parsing, formatting, rounding, edge cases, and serialization
To run tests:
vendor/bin/phpunitThis library is inspired by and originally based on Kevin Hill’s php-duration, with significant improvements in architecture, extensibility, and formatting capabilities.
Parsing, formatting, and conversion logic has been modernized and tested.
MIT © Demir Karić
See LICENSE file for details.