Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zoho/hawking
A Natural Language Date Time Parser that Extract date and time from text with context and parse to the required format
https://github.com/zoho/hawking
configurations-hawking corenlp date-parser dateformat datetime datetimepicker machinelearning nlp nlp-libary parse-dates timeparser timezones
Last synced: 6 days ago
JSON representation
A Natural Language Date Time Parser that Extract date and time from text with context and parse to the required format
- Host: GitHub
- URL: https://github.com/zoho/hawking
- Owner: zoho
- Created: 2020-12-09T09:24:26.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2024-09-24T14:59:33.000Z (4 months ago)
- Last Synced: 2025-01-09T08:08:03.867Z (13 days ago)
- Topics: configurations-hawking, corenlp, date-parser, dateformat, datetime, datetimepicker, machinelearning, nlp, nlp-libary, parse-dates, timeparser, timezones
- Language: Java
- Homepage:
- Size: 76.4 MB
- Stars: 223
- Watchers: 7
- Forks: 23
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: licenses/gpl-3.0/LICENSE.txt
Awesome Lists containing this project
README
HAWKING
A natural language date parser written in Java
About •
Key Features •
Configurations
## About
Given any date expression in a sentence, Hawking will apply standard language recognition and parser techniques to produce a list of corresponding dates with optional parse and syntax information.
It supports for almost every existing date format: absolute dates, relative dates(on Sunday, at 12 PM,
at 04/11/2021, etc)###### Here is sample input:
``` java
HawkingTimeParser parser = new HawkingTimeParser();
String inputText = "Good morning, Have a nice day. Shall we meet on December 20 ?";
DatesFound datesFound = parser.parse(inputText, referenceDate, hawkingConfiguration, "eng");//"eng" refers to English language
//referenceDate, hawkingConfiguration are explained in detail below
```
###### Output object "datesFound" contains following information and more:```
Text : on December 20
Start : 2021-12-20T00:00:00.000+05:30
End : 2021-12-20T23:59:59.000+05:30
```
Check out the Demo file:
[```HawkingDemo```](https://github.com/zoho/hawking/tree/master/src/main/java/com/zoho/hawking/HawkingDemo.java)### Releases
Hawking date time parser releases are available in the [Maven Central repository](https://mvnrepository.com/artifact/com.zoho/hawking)#### Models
The models used in Hawking Time Parser in the latest code are listed below.*```Parser Model : Custom NER model to parse all dates in a sentence ```
> src/main/resources/parser/parser.crf.ser.gz*```Stanford NLP POS Tagger: Used for Tense Prediction```
> src/main/resources/tense/english-left3words-distsim.tagger## Key Features
Here are some key features of Hawking Time Parser,#### *Tense Consideration :*
Tense of the sentence is considered while parsing date.
```
I met you on Monday
I will meet you on Monday
```#### *Context Understanding :*
Hawking Time Parser can understand and detect the date components based on context.
```
Good morning, I am so happy to see you(No dates)
Sun rises in the east(No dates) -- On sun, John met Lisa(Date: on sun)
I watched Tomorrow Never Dies(No dates) -- Can we go to the movie tomorrow ?(Date: tomorrow)
```#### *Multiple Dates :*
It can detect multiple dates for a given input.
```
I am going for a trade show at evening. From December 2nd, most of the companies will be open in Tamil Nadu. (Dates: at evening, from December 2nd)
```#### *Date Time Relation and Duration :*
Hawking time parser can parse duration or span cases .
```
Next 2 weeks, I am going to London for a conference.
We have been working on this project for 3 months.
Call me in 2 hours.
```
#### *Prefix & Postfix Importance :*
Prefix and postfix plays a vital role in parsing datetime text. Each prefix/postfix refers different date and time
```
Prefix -> Since Monday, Next Monday, within Monday, for Monday.
Postfix -> 2 weeks back, 10 months ago, 5 hours later.
```
Hawking time Parser can account 30+ prefix and suffix while parsing and returns date as input referred to(since, from, till, until, within, for, at, on, in, next, last, past and so on).
#### *Complex cases :*
Hawking can detect and parse date time more than 5 words.
```
next year 1st weekend Sunday morning 9 am
```
#### *Reference time :*
A reference time is the time from which date text has to be parsed
```
*Let's say reference time = 01/11/2020 9:00 AM
Input : "I will call at 2 PM"
output = 01/11/2020 2:00 PM*Let's say reference time = 01/11/2020 8:00 PM
Input : "I will call at 2 PM"
Output = 02/11/2020 2:00 PM (As input is in future tense at night
8 PM, it's obvious that it refers to tomorrow)
```
So parsing dates based on input reference time is a base for Hawking time parser(if reference time is not passed, current system time will be default reference time)
#### *Time Zone Handling :*
Hawking time parser can parse dates and time along with timezone. Currently it supports 500+ Time zones
```
Call me at 9 AM Singapore time
I will schedule demo at 13:30 PST
Meeting will start at 10:00 AM (Asia/Calcutta)
```
## Configurations
Hawking time Parser's versatility allows to the user to configure everything in the way they need the date text to parsed.#### *Needs for configuration :*
Even though date and time is globally referred by same common words in English, the context of date text can differs from person to person, locale to locale, country to country, business to business.
```
When someone says "we will go out on weekend "
-> In India it's Saturday and Sunday
-> In UAE it's Friday and SaturdayDate formats :
In Europe = DD/MM/YYYY
In United States = MM/DD/YYYY
```
So Hawking Configurations enable user to control the date and time output based on their perspective and requirements.#### *Cases for configurations :*
Hawking Time Parser allows user set configuration to 30+ date and time components based on the needs.*```Show me meeting schedules for next 2 days```
> User can expect next 48 hours or next 2 days (from tomorrow))
*```Show me meeting schedules for next week```
> WeekStart and WeekEnd can be given by user like Sunday to Saturday. For Business model user can set week to represent only weekdays-Monday to Friday
*```I will call you at 12 am```
> User can set their time zone as default timezone instead of mentioning timezone in input every time
*```Schedule meeting on 07/12/2020```
> User can set default dateformats like (DD/MM/YYYY or MM/DD/YYYY) more than 20 DateFormats is supported.
#### *Business Custom Cases:*
Hawking time parser supports business date cases like Fiscal year, Financial year, Annual year, quarterly, Q3, etc.
```
* Revenue generated this quarter
* In the last fiscal year, our company reached more than 20 million users
```
Users can set configuration for the Fiscal year start and end too based on their business model (February to January or April to March...)***To understand the Hawking configuration input, check:*** [HawkingConfiguration](https://github.com/zoho/hawking/blob/master/src/main/java/com/zoho/hawking/datetimeparser/configuration/HawkingConfiguration.java)