A parser for date and time written in natural language for PHP.
- Installation
- Usage
- Languages support
- ToDo
The preferred way to install package is via composer:
composer require wapmorgan/time-parser
Parse some input from user and receive a DateTime
object.
-
Create a Parser object
$parser = new wapmorgan\TimeParser\TimeParser('all'); // If you set second argument of constructor to `true`, TimeParser will be able to parse alphabetic values. Numbers up to 20 are available to use. $parser = new wapmorgan\TimeParser\TimeParser('all', true);
First argument is a language. Applicable values:
'all'
(by default) - scan for all available languages. Use it when you can not predict user's preferred language.'russian'
- scan only as string written in one language.array('english', 'russian')
- scan as english and then the rest as russian.
-
Parse string and return a
DateTimeImmutable
object. If second argument istrue
, method will returnfalse
when no date&time strings found.$datetime = $parser->parse(fgets(STDIN)); // next call returns false $datetime = $parser->parse('abc', true);
For this moment four languages supported: Russian, English, French and German. Two languages support is in progress: Chinese, Spanish.
Their rules are in rules
catalog so you can improve TimeParser by adding new language or by improving existing one.
Languages with examples of strings containing date&time:
Language | Example |
---|---|
chinese | 15:12:13 下星期一 下年 二月 経由15小时 経由10分钟 経由11秒钟 経由5年 経由2星期 経由1天 経由10月 |
english | 15 december 1977 at 15:12:13 next monday next year in february in 15 hours in 10 minutes in 11 seconds in 5 years in 2 weeks in 1 day in 10 months |
french | 15:12:13 prochaine lundi prochaine année février bout de 15 heures bout de 10 minutes bout de 11 secondes bout de 5 années bout de 2 semaines bout de 1 jour bout de 10 mois |
german | 15:12:13 nächsten montag nächsten jahr im februar nach 15 uhr nach 10 minuten nach 11 secunden nach 5 jahre nach 2 wochen nach 1 tag nach 10 monate |
russian | 15 декабря 1977 года в 15:12:13 в следующий понедельник в следующем году в феврале через 15 часов через 10 минут через 11 секунд через 5 лет через 2 недели через 1 день через 10 месяцев |
spanish | 15:12:13 el próximo lunes en próximo año en febrero en 15 horas en 10 minutos en 11 segundos en 5 años en 2 semanas en 1 día en 10 meses |
For developing reasons you may would like to see process of parsing. To do this call related methods:
TimeParser::enableDebug();
// and
TimeParser::disableDebug();
To understand, how it works, look at substrings separately:
- 15 december 1977 - absolute date
- at 15:12:13 - absolute time
- next monday or this friday - absolute date
- next year or 2016 year - absolute date
- in february or next month - absolute date
- next week - absolute date
- in 15 hours - relative time
- in 10 minutes - relative time
- in 11 seconds - relative time
- in 2 weeks - relative date
- in 1 day - relative date
- in 10 months - relative date
- Tests.
- Try to parse combinations: in 5 hours and 2 minutes.
- Try to parse alphabetic offsets: in five hours and через пять часов.
- Chinese - check hieroglyphs.
- Spanish - check prepositions.
- Portuguese
- Arabic
- Korean