Skip to main content

An extension for IPython that help to define django's models in your interactive session.

Project description

Latest PyPI version Number of PyPI downloads
author:

Martín Gaitán <gaitan@gmail.com>

homepage:

https://github.com/mgaitan/django-orm-magic

documentation:

see this notebook

Define your django models in an IPython cell and use them on the fly. Let the magic do the boring part.

Django ORM isn’t conceived to be used standalone. Even for a trivial case, you need to configure a database, create an app, etc. This magic handle that automatically, and then import every model to your interactive session.

Install

You can install or upgrade via pip

pip install -U django-orm-magic

or directly from the repository using the %install_ext magic command:

In[1]: %install_ext https://raw.github.com/mgaitan/django-orm-magic/master/django_orm_magic.py

Basic usage

Once it’s installed, you can load it with %load_ext django_orm_magic. Then define your models in a cell started with the cell magic %%django_orm. For example:

In[2]: %load_ext django_orm_magic


In[3]: %%django_orm

       from django.db import models

       class Poll(models.Model):
           question = models.CharField(max_length=200)
           pub_date = models.DateTimeField('date published')

       class Choice(models.Model):
           poll = models.ForeignKey(Poll)
           choice_text = models.CharField(max_length=200)
           votes = models.IntegerField(default=0)

And it’s done. Every model is synced in a sqlite database named db.sqlite in your current path and imported automatically:

In[4]: Poll.objects.all()
Out[4]: []

In[5]: from django.utils import timezone
       p = Poll(question="What's new?", pub_date=timezone.now())
       p.save()

See the documentation for further details.

See here for another example

Changelog

0.3.1 / 2014-01-21

  • Fix bug #4 (now install via pip works)

0.3 / 2013-12-14

  • Added %django_settings magic

  • Added a tutorial notebook

0.2 / 2013-12-11

  • Moved the code to github.

  • Packaged and registered in PyPi

0.1 / 2013-10-29

  • First public release (as a gist)

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

django-orm-magic-0.4.tar.gz (3.8 kB view details)

Uploaded Source

File details

Details for the file django-orm-magic-0.4.tar.gz.

File metadata

File hashes

Hashes for django-orm-magic-0.4.tar.gz
Algorithm Hash digest
SHA256 fe83fc51fd5673b7a8070fd1a96f1f516ee4ac86b5e45723ad9856ec19576161
MD5 56f312f996df55c261569077dc740072
BLAKE2b-256 e36827afcabaeee2c022bb88fcc58becb8afa8ae90f325cc7bfa3aeb24ba901a

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