Skip to main content

Fraction display and form fields for Django

Project description

https://badge.fury.io/py/django-fractions.png https://travis-ci.org/jmichalicek/django-fractions.png?branch=master

Fraction display and form fields for Django

Documentation

The full documentation is at https://django-fractions.readthedocs.org.

Quickstart

Install django-fractions:

pip install django-fractions

Add djfractions to settings.INSTALLED_APPS

Then use it in a project:

import djfractions

In templates:

{% load fractions %}
{% display_fraction 1.25 %}

In Forms:

from djfractions.forms import DecimalFractionField
from django import forms

class MyForm(forms.Form):
    a_fraction = DecimalFractionField()

Features

  • Template tag for displaying float and Decimal values as fractions including mixed numbers

  • DecimalFractionField form field which handles input such as “1/4”, “1 1/2”, “1 and 1/2”, and converts to a decimal.Decimal instance

TODO

  • Add unicode_fraction template tag to display the unicode fraction entity if available

  • forms.FloatDecimalField to return a float rather than Decimal

  • forms.SplitFractionWidget for having separate numerator and denominator form fields

  • forms.SplitMixedFractionWidget for handling mixed number fractions with separate fields

  • models.DecimalBackedFractionField() to store a Decimal value but return/accept it as a fraction

  • models.FloatBackedFractionField() to store a Decimal value but return/accept it as a fraction

Cookiecutter Tools Used in Making This Package

  • cookiecutter

  • cookiecutter-djangopackage

History

Current

1.0.0 (2016.12-31)

  • Stop subclassing Django’s DecimalField and duplicate small amounts of code as necessary for db backend compatibility. Too many things need to be handled differently. Main cause of major version bump.

  • Update forms.FractionField to skip over max_digits and decimal_places kwargs which will get passed in by models.fields.DecimalFractionField

  • Add models.fields.DecimalFractionField.formfield() so that a forms.FractionField will be used by default

  • Fix quantity_to_decimal and quantity_to_fraction to strip leading and trailing spaces before pattern matching and converting to a decimal or fraction

  • Allow for leading negative sign with forms.FractionField input values

  • Fix is_fraction() to allow leading negative sign

  • Add max_digits and decimal_places params to DecimalFractionField in test model

  • Additional test cases for models.fields.DecimalFractionField

0.4.0 (2016-08-29)

  • Added djfractions.models.DecimalFractionField which stores fractions.Fraction values as decimals in the dataase.

  • Better usage of tox to test against different Python and Django versions

  • Added testing against Django 1.10

0.3.2 (2015-08-28)

  • Fixed boolean logic for when to coerce values to thirds in in forms.DecimalFractionField and get_fraction_parts()

0.3.1 (2015-08-12)

  • HISTORY.rst typo fixes

  • pypi release version fix

0.3.0 (2015-08-12)

  • Added forms.FractionField which returns fractions.Fraction instances

  • Refactoring of common code with new forms.FractionField

  • Smarter checking for numeric types throughout the code

  • forms.DecimalFractionField.to_python() handles fractions.Fraction values now

  • Fixed bug handling negative numbers in quantity_to_decimal()

  • Added min_value and max_value to forms.DecimalFractionField

  • Made coerce_thirds, limit_denominator, and use_mixed_numbers params to DecimalFractionField proper named parameters and not just kwargs.

0.2.1 (2015-08-06)

  • Fixed typo in usage docs

0.2.0 (2015-08-06)

  • display_fraction template tag output is templated so that its formatting can be changed by users

  • Added new display_improper_fraction template tag to simplify the common case of wanting to only use improper fractions with no whole numbers

  • Added unicode_entity to template context for display_fraction and display_improper_fraction so that the html entity for common fractions may be used rather than <sup> and <sub> tags

  • Refactored lots of code out into smaller, reusable functions

  • Added a bunch of test cases

0.1.0 (2015-08-01)

  • 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

django-fractions-1.0.0.tar.gz (14.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

django_fractions-1.0.0-py2.py3-none-any.whl (14.9 kB view details)

Uploaded Python 2Python 3

File details

Details for the file django-fractions-1.0.0.tar.gz.

File metadata

File hashes

Hashes for django-fractions-1.0.0.tar.gz
Algorithm Hash digest
SHA256 be8f2b86d0b24ed6042407f4714cf8fb82805cd6414dc3d1537163394911d797
MD5 491ef82982cffbc4aeb72434443aeb37
BLAKE2b-256 d404f9babf64b52e928702803ef67b39b572d889ea10cc75519347851a78a20e

See more details on using hashes here.

File details

Details for the file django_fractions-1.0.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for django_fractions-1.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 9480f2a5375ae0366e2958ffcbc489921e25be645b5a948b96fd4416fd7ff453
MD5 355af2a7d3ffe3ed435ec3625669a468
BLAKE2b-256 6cef4836aa9ee04f378696d23d0eed463d0000610b6b217381e7934c890709c7

See more details on using hashes here.

Supported by

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