A set of functions related with Django
Project description
Installation
pip install django-extra-tools
Quick start
Enable django-extra-tools
INSTALLED_APPS = [
...
'django_extra_tools',
]
Install SQL functions
python manage.py migrate
StringAgg aggregate function on Django 1.4 needs monkey patch
from django_extra_tools.monkey import patch_django
patch_all()
Template filters
parse_datetime
Parse datetime from string.
{% load parse %}
{{ string_datetime|parse_datetime|date:"Y-m-d H:i" }}
parse_date
Parse date from string.
{% load parse %}
{{ string_date|parse_date|date:"Y-m-d" }}
parse_time
Parse time from string.
{% load parse %}
{{ string_time|parse_time|date:"H:i" }}
parse_duration
Parse duration (timedelta) from string.
{% load parse %}
{{ string_duration|parse_duration }}
Aggregation
First
Returns the first non-NULL item.
from django_extra_tools.db.models.aggregates import First
Table.objects.aggregate(First('col1', order_by='col2'))
Last
Returns the last non-NULL item.
from django_extra_tools.db.models.aggregates import Last
Table.objects.aggregate(Last('col1', order_by='col2'))
Median
Returns median value.
from django_extra_tools.db.models.aggregates import Median
Table.objects.aggregate(Median('col1'))
StringAgg
Combines the values as the text. Fields are separated by a “separator”.
from django_extra_tools.db.models.aggregates import StringAgg
Table.objects.aggregate(StringAgg('col1'))
Database functions
batch_qs
Returns a (start, end, total, queryset) tuple for each batch in the given queryset.
from django_extra_tools.db.models import batch_qs
qs = Table.objects.all()
start, end, total, queryset = batch_qs(qs, 10)
pg_version
Return tuple with PostgreSQL version of a specific connection.
from django_extra_tools.db.models import pg_version
version = pg_version()
HTTP Response
HttpResponseGetFile
An HTTP response class with the “download file” headers.
from django_extra_tools.http import HttpResponseGetFile
return HttpResponseGetFile(filename='file.txt', content=b'file content', content_type='file/text')
WSGI Request
get_client_ip
Get the client IP from the request.
from django_extra_tools.wsgi_request import get_client_ip
ip = get_client_ip(request)
Management
OneInstanceCommand
A management command which will be run only one instance of command with name name. No other command with name name can not be run in the same time.
from django_extra_tools.management import OneInstanceCommand
class MyCommand(OneInstanceCommand):
name = 'mycommand'
def handle_instance(self, *args, **kwargs):
# some operations
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
Built Distribution
Hashes for django-extra-tools-0.1.0b2.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | dba9214f2621de900af28f11825c0249a7da5779142248824d6c61967f6776e6 |
|
MD5 | f2c6441a6e897abbf944206370b63753 |
|
BLAKE2b-256 | 9506e792e02d299455d7b56ab5b0a4089973061b7260c8bc365e39fd585c3f1e |
Hashes for django_extra_tools-0.1.0b2-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | bf795424a01eadd09826e0e74d18df244ecb8a76066c20cbc8d0fb711663ccf5 |
|
MD5 | ee06dc8299aa682de3ac9b001dd894b0 |
|
BLAKE2b-256 | f2ff30210e22178c9b731581052fe8b02a1a518f867db68924e8f0739de87494 |