Validation and parsing library
Project description
Read The Docs hosted documentation <http://trafaret.readthedocs.org/en/latest/> or look to the docs/api/intro.rst for start.
Trafaret is rigid and powerful lib to work with foreign data, configs etc. It provides simple way to check anything, and convert it accordingly to your needs.
For simple example what can be done:
import datetime import trafaret as t date = t.Dict(year=t.Int, month=t.Int, day=t.Int) >> (lambda d: datetime.datetime(**d)) assert date.check({'year': 2012, 'month': 1, 'day': 12}) == datetime.datetime(2012, 1, 12)
Work with regex:
>>> c = t.String(regex=r'^name=(\w+)$') >> (lambda m: m.groups()[0]) >>> c.check('name=Jeff') 'Jeff'
Change dict names:
>>> c = t.Dict(t.Key('uNJ') >> 'user_name': t.String}) >>> c.check({'uNJ': 'Adam'}) {'user_name': 'Adam'}
Arrow date checking:
import arrow def check_datetime(str): try: return arrow.get(str).naive except arrow.parser.ParserError: return t.DataError('value is not in proper date/time format')
Yes, you can write trafarets that simple.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
trafaret-0.6.1.tar.gz
(16.5 kB
view hashes)
Built Distribution
trafaret-0.6.1-py3-none-any.whl
(18.1 kB
view hashes)