Git Product home page Git Product logo

django-unixdatetimefield's Introduction

django-unixdatetimefield

image

Latest Version

Downloads

Provides a UnixDateTimeField for your Django models.

I have found this especially useful when integrating Django into legacy databases, where the typical DateTime column type is rather stored as a Unix timestamp (http://en.wikipedia.org/wiki/Unix_time).

UnixDateTimeField is based on the implementation of the standard Django DateTimeField, making it 100% compatible with all features and options it supports.

Usage

First you'll need to attach a UnixDateTimeField to your model. This acts as a the equivalence of a Django PositiveIntegerField at the database level but provides a Django DateTimeField at the ORM abstraction layer.

Example model:

from django_unixdatetimefield import UnixDateTimeField

class MyModel(models.Model):
    created_at = UnixDateTimeField()

Python ORM query:

>>> m = MyModel()
>>> m.created_at = datetime.datetime(2015, 2, 21, 19, 38, 32, 209148)
>>> m.save()

Database:

sqlite> select created_at from mymodel;
1426967129

Enjoy!

Installation

Install with pip (or easy_install):

pip install django-unixdatetimefield

License

BSD, just as the main Django project. See LICENSE file in root of this repo.

Contributing

This project accepts contributions via GitHub pull requests.

django-unixdatetimefield's People

Contributors

niklas9 avatar

Watchers

 avatar

django-unixdatetimefield's Issues

There is a ValueError in the UnixDataTimeField.to_python() method

There is a ValueError in the UnixDataTimeField.to_python() method.

I will a copy the complete error message

Rapid solution:

#!/usr/bin/python

-- coding: UTF-8 --

from future import unicode_literals

import datetime
import time

import django.db.models as models

from django.utils.dateparse import parse_datetime

class UnixDateTimeField(models.DateTimeField):

# TODO(niklas9):
# * should we take care of transforming between time zones in any way here ?
# * get default datetime format from settings ?
DEFAULT_DATETIME_FMT = '%Y-%m-%d %H:%M:%S'
# TODO(niklas9):
# * metaclass below just for Django < 1.9, fix a if stmt for it?
#__metaclass__ = models.SubfieldBase
description = "Unix timestamp integer to datetime object"

def get_internal_type(self):
    return 'PositiveIntegerField'

def to_python(self, val):
    if val is None or isinstance(val, datetime.datetime):
        return val
    if isinstance(val, datetime.date):
        return datetime.datetime(val.year, val.month, val.day)
        
    try:
        date_value = datetime.datetime.fromtimestamp(float(val))
        return date_value            
    except ValueError:
        # parse the following value : ('2016-10-03 19:00:00+0200'
        date_value = parse_datetime(val)
        return date_value

def get_db_prep_value(self, val, *args, **kwargs):
    if val is None:  return None
    return int(time.mktime(val.timetuple()))

def value_to_string(self, obj):
    val = self._get_val_from_obj(obj)
    return self.to_python(val).strftime(self.DEFAULT_DATETIME_FMT)

def from_db_value(self, val, expression, connection, context):
    return self.to_python(val)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.