Skip to main content

Date parsing library designed to parse dates from HTML pages

Project description

travis build status pypi downloads per day pypi version

dateparser provides modules to easily parse localized dates in almost any string formats commonly found on web pages.

Features

  • Generic parsing of dates in English, Spanish, Dutch, Russian and several other langauges and formats.

  • Generic parsing of relative dates like: '1 min ago', '2 weeks ago', '3 months, 1 week and 1 day ago'.

  • Generic parsing of dates with time zones abbreviations like: 'August 14, 2015 EST', 'July 4, 2013 PST'.

  • Extensive test coverage.

Usage

The most straightforward way is to use the dateparser.parse function, that wraps around most of the functionality in the module.

Relative Dates

>>> parse('1 hour ago')
datetime.datetime(2015, 5, 31, 23, 0)
>>> parse(u'Il ya 2 heures')  # French (2 hours ago)
datetime.datetime(2015, 5, 31, 22, 0)
>>> parse(u'1 anno 2 mesi')  # Italian (1 year 2 months)
datetime.datetime(2014, 4, 1, 0, 0)
>>> parse(u'yaklaşık 23 saat önce')  # Turkish (23 hours ago)
datetime.datetime(2015, 5, 31, 1, 0)
>>> parse(u'Hace una semana')  # Spanish (a week ago)
datetime.datetime(2015, 5, 25, 0, 0)
>>> parse(u'2小时前')  # Chinese (2 hours ago)
datetime.datetime(2015, 5, 31, 22, 0)

Dependencies

dateparser translates non-english dates to English and uses dateutil module 'parser' to parse the translated date.

Also, it requires PyYAML for its language detection module to work.

Limitations

dateparser at this point does not support generic parsing of dates with fixed UTC offsets. This restricts its ability to reliably parse time zone aware dates since the use of abbreviated time zones as a sole designator of time zones is not recommended.

Read Wikipedia Time Zone article for more information.

History

0.2.0 (2015-06-17)

  • Languages definitions using YAML.

  • Using translation based approach for parsing non-english languages. Previously, dateutil.parserinfo was used for language definitions.

  • Better period extraction.

  • Improved tests.

  • Added a number of new simplifications for more comprehensive generic parsing.

  • Improved validation for dates.

  • Support for Polish, Thai and Arabic dates.

  • Support for pytz timezones.

  • Fixed building and packaging issues.

0.1.0 (2014-11-24)

  • First release on PyPI.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dateparser-0.2.0.tar.gz (53.1 kB view details)

Uploaded Source

Built Distribution

dateparser-0.2.0-py2.py3-none-any.whl (31.8 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file dateparser-0.2.0.tar.gz.

File metadata

  • Download URL: dateparser-0.2.0.tar.gz
  • Upload date:
  • Size: 53.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for dateparser-0.2.0.tar.gz
Algorithm Hash digest
SHA256 65dc9dac4f2984e3b9761726329d16bafc368f68e25d944f1b97021662e2d33c
MD5 a449ae34c451df2c1a364afbd02a2205
BLAKE2b-256 aaa374b4581a119894b0719e58c61ba1f97a90712ea25c4c468881eb744f3f06

See more details on using hashes here.

File details

Details for the file dateparser-0.2.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for dateparser-0.2.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 252e2ce6170e0a70f63c52ba59376e1b1e13f81c4612c416690ebaa96e9d71c6
MD5 519d5f12383afead618f8deb3d85058b
BLAKE2b-256 07b7510241d05bbfd8c0a4b4aee919e8c3f5f7093b38727b565c845d457611e4

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page