Skip to main content

Declarative dictionary-based read-only model classes for Python

Project description

# micromodels

A simple library for building read-only model classes based on dictionaries of data.

Perfect for (amongst other things) wrapping Python objects around JSON data returned from web-based APIs.

## Really simple example

import micromodels

class Author(micromodels.Model):
first_name = micromodels.CharField()
last_name = micromodels.CharField()
date_of_birth = micromodels.DateField(format="%Y-%m-%d")

@property
def full_name(self):
return "%s %s" % (self.first_name, self.last_name)


douglas_data = {
"first_name": "Douglas",
"last_name": "Adams",
"date_of_birth": "1952-03-11",
}

douglas = Author(douglas_data)
print "%s was born in %s" % (douglas.full_name, douglas.date_of_birth.strftime("%Y"))

## Slightly more complex example

import json
from urllib2 import urlopen

import micromodels

class TwitterUser(micromodels.Model):
id = micromodels.IntegerField()
screen_name = micromodels.CharField()
name = micromodels.CharField()
description = micromodels.CharField()

def get_profile_url(self):
return 'http://twitter.com/%s' % self.screen_name


class Tweet(micromodels.Model):
id = micromodels.IntegerField()
text = micromodels.CharField()
created_at = micromodels.DateTimeField(format="%a %b %d %H:%M:%S +0000 %Y")
user = micromodels.ModelField(TwitterUser)


json_data = urlopen('http://api.twitter.com/1/statuses/show/20.json')
tweet = Tweet(json.load(json_data))

print "Tweet was posted by %s (%s) on a %s" % (
tweet.user.name,
tweet.user.get_profile_url(),
tweet.created_at.strftime("%A")
)


## Field reference

### Field options

The following optional argument is available for all field types.

#### `source`

By default, a model class will look for a key in its source data with the same name as each of its fields. For example:

class ExampleModel(micromodels.Model):
myfield = micromodels.CharField()

>>> e = ExampleModel({'myfield': 'Some Value'})
>>> e.myfield
u'Some Value'

If you wish to change this, you can pass the 'source' argument to each field instance:

class ExampleModel(micromodels.Model):
myfield = micromodels.CharField()
anotherfield = micromodels.CharField(source='some_other_field')

>>> e = ExampleModel({'myfield': 'Some Value', 'some_other_field': 'Another Value'})
>>> e.anotherfield
u'Another Value'

### Field types

#### PassField

The simplest type of field - this simply passes through whatever is in the data dictionary without changing it at all.

#### CharField

A field for string data. **Will attempt to convert its supplied data to Unicode.**

#### IntegerField

Attempts to convert its supplied data to an integer.

#### BooleanField

Attempts to convert its supplied data to a boolean. If the data is a string, `"true"` (case insensitive) will be converted to `True` and all other strings will be converted to `False`. If the supplied data is an integer, positive numbers will become `True` and negative numbers or zero will become `False`.

#### DateTimeField

Converts its supplied data to a Python `datetime.datetime` object using the format given in the required `format` argument. See [the Python documentation](http://docs.python.org/library/datetime.html#strftime-strptime-behavior) for details of the format string. For example:

class MyModel(micromodels.Model):
created_at = micromodels.DateTimeField(format="%a %b %d %H:%M:%S +0000 %Y")

#### DateField

Converts its supplied data to a Python `datetime.date` object using the format given in the required `format` argument (see `DateTimeField` for details).

#### TimeField

Converts its supplied data to a Python `datetime.time` object using the format given in the required `format` argument (see `DateTimeField` for details).

#### FieldCollectionField

Use this field when your source data dictionary contains a list of items of the same type. It takes a single required argument, which is the field type that should be used to convert each item in the list. For example:

some_data = {
'first_list': [0, 34, 42],
'second_list': ['first_item', 'second_item', 'third_item'],
}

class MyModel(micromodels.Model):
first_list = micromodels.FieldCollectionField(micromodels.IntegerField)
second_list = micromodels.FieldCollectionField(micromodels.CharField)

>>> m = MyModel(some_data)
>>> m.first_list
[0, 34, 42]
>>> m.second_list
[u'first_item', u'second_item', u'third_item']

#### ModelField

Use this field when you wish to nest one object inside another. It takes a single required argument, which is the nested class. For example, given the following dictionary:

some_data = {
'first_item': 'Some value',
'second_item': {
'nested_item': 'Some nested value',
},
}

You could build the following classes (note that you have to define the inner nested models first):

class MyNestedModel(micromodels.Model):
nested_item = micromodels.CharField()

class MyMainModel(micromodels.Model):
first_item = micromodels.CharField()
second_item = micromodels.ModelField(MyNestedModel) # pass the class of the nested model

Then you can access the data as follows:

>>> m = MyMainModel(some_data)
>>> m.first_item
u'Some value'
>>> m.second_item.__class__.__name__
'MyNestedModel'
>>> m.second_item.nested_item
u'Some nested value'

#### ModelCollectionField

Use this field when your source data dictionary contains a list of dictionaries. It takes a single required argument, which is the name of the nested class that each item in the list should be converted to. For example:

some_data = {
'list': [
{'value': 'First value'},
{'value': 'Second value'},
{'value': 'Third value'},
]
}

class MyNestedModel(micromodels.Model):
value = micromodels.CharField()

class MyMainModel(micromodels.Model):
list = micromodels.ModelCollectionField(MyNestedModel)

>>> m = MyMainModel(some_data)
>>> len(m.list)
3
>>> m.list[0].__class__.__name__
'MyNestedModel'
>>> m.list[0].value
u'First value'
>>> [item.value for item in m.list]
[u'First value', u'Second value', u'Third value']


## (Un)license

This is free and unencumbered software released into the public domain.

Anyone is free to copy, modify, publish, use, compile, sell, or distribute this software, either in source code form or as a compiled binary, for any purpose, commercial or non-commercial, and by any means.

In jurisdictions that recognize copyright laws, the author or authors of this software dedicate any and all copyright interest in the software to the public domain. We make this dedication for the benefit of the public at large and to the detriment of our heirs and successors. We intend this dedication to be an overt act of relinquishment in perpetuity of all present and future rights to this software under copyright law.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

For more information, please refer to <http://unlicense.org/>

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

micromodels-0.1.0.tar.gz (6.7 kB view details)

Uploaded Source

File details

Details for the file micromodels-0.1.0.tar.gz.

File metadata

  • Download URL: micromodels-0.1.0.tar.gz
  • Upload date:
  • Size: 6.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for micromodels-0.1.0.tar.gz
Algorithm Hash digest
SHA256 749e240f2f6187eaa00b8945ad7c49c9cafbad4686e6bdda7e1ba400facc063c
MD5 5d6ea900edff5cd9d7d5f7cde8fe0431
BLAKE2b-256 18e3c22473d6d960df227d023a60b135b7eb29e0e790912034fe05b508ee0525

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