typeconv_datetime_stdlib.py :  » Database » KInterbasDB » kinterbasdb-3.2 » Python Open Source

Home
Python Open Source
1.3.1.2 Python
2.Ajax
3.Aspect Oriented
4.Blog
5.Build
6.Business Application
7.Chart Report
8.Content Management Systems
9.Cryptographic
10.Database
11.Development
12.Editor
13.Email
14.ERP
15.Game 2D 3D
16.GIS
17.GUI
18.IDE
19.Installer
20.IRC
21.Issue Tracker
22.Language Interface
23.Log
24.Math
25.Media Sound Audio
26.Mobile
27.Network
28.Parser
29.PDF
30.Project Management
31.RSS
32.Search
33.Security
34.Template Engines
35.Test
36.UML
37.USB Serial
38.Web Frameworks
39.Web Server
40.Web Services
41.Web Unit
42.Wiki
43.Windows
44.XML
Python Open Source » Database » KInterbasDB 
KInterbasDB » kinterbasdb 3.2 » typeconv_datetime_stdlib.py
# KInterbasDB Python Package - Type Conv : DateTime/Python 2.3+ Standard Library
#
# Version 3.1
#
# The following contributors hold Copyright (C) over their respective
# portions of code (see license.txt for details):
#
# [Original Author (maintained through version 2.0-0.3.1):]
#   1998-2001 [alex]  Alexander Kuznetsov   <alexan@users.sourceforge.net>
# [Maintainers (after version 2.0-0.3.1):]
#   2001-2002 [maz]   Marek Isalski         <kinterbasdb@maz.nu>
#   2002-2004 [dsr]   David Rushby          <woodsplitter@rocketmail.com>
# [Contributors:]
#   2001      [eac]   Evgeny A. Cherkashin  <eugeneai@icc.ru>
#   2001-2002 [janez] Janez Jere            <janez.jere@void.si>

__all__ = (
    # kinterbasdb-native date and time converters:
    'date_conv_in', 'date_conv_out',
    'time_conv_in', 'time_conv_out',
    'timestamp_conv_in', 'timestamp_conv_out',

    # DB API 2.0 standard date and time type constructors:
    'Date', 'Time', 'Timestamp',
    'DateFromTicks', 'TimeFromTicks', 'TimestampFromTicks',
  )

from kinterbasdb.k_exceptions import *

# THIS CONVERSION MODULE IS NOT EXPECTED TO WORK WITH < PYTHON 2.3,
# since it uses the standard datetime module for its date/time operations.
import datetime as dt

################################################################################
## DATE AND TIME
################################################################################

# kinterbasdb-native date and time converters:
def date_conv_in(dtObj):
    # Allow implicit param conv:
    if dtObj is None or isinstance(dtObj, basestring):
        return dtObj

    if not isinstance(dtObj, dt.date):
        raise InterfaceError(
            'Required type: %s ; supplied type: %s'
            % ( str(dt.date), str(type(dtObj)) )
          )
    return dtObj.timetuple()[:3]

def date_conv_out(dateTuple):
    if dateTuple is None:
        return None
    return dt.date(*dateTuple)


def time_conv_in(tmObj):
    # Allow implicit param conv:
    if tmObj is None or isinstance(tmObj, basestring):
        return tmObj

    if not isinstance(tmObj, dt.time):
        raise InterfaceError(
            'Required type: %s ; supplied type: %s'
            % ( str(dt.time), str(type(tmObj)) )
          )
    timeTuple = (tmObj.hour, tmObj.minute, tmObj.second, tmObj.microsecond)
    return timeTuple

def time_conv_out(timeTuple):
    if timeTuple is None:
        return None
    return dt.time(*timeTuple)


def timestamp_conv_in(tsObj):
    # Allow implicit param conv:
    if tsObj is None or isinstance(tsObj, basestring):
        return tsObj

    if not isinstance(tsObj, dt.datetime):
        raise InterfaceError(
            'Required type: %s ; supplied type: %s'
            % ( str(dt.datetime), str(type(tsObj)) )
          )

    timestampTuple = (
        tsObj.year, tsObj.month, tsObj.day,
        tsObj.hour, tsObj.minute, tsObj.second, tsObj.microsecond
      )
    return timestampTuple

def timestamp_conv_out(timestampTuple):
    if timestampTuple is None:
        return None
    return dt.datetime(*timestampTuple)


# DB API 2.0 standard date and time type constructors:
def _makeFilteredConstructor(underlyingConstructor):
    def Constructor(*args, **kwargs):
        try:
            return underlyingConstructor(*args, **kwargs)
        except ValueError, e:
            raise DataError(str(e))
    return Constructor

Date = _makeFilteredConstructor(dt.date)
Time = _makeFilteredConstructor(dt.time)
Timestamp = _makeFilteredConstructor(dt.datetime)

DateFromTicks = _makeFilteredConstructor(dt.date.fromtimestamp)
TimeFromTicks = _makeFilteredConstructor(lambda ticks: TimestampFromTicks(ticks).time())
TimestampFromTicks = _makeFilteredConstructor(dt.datetime.fromtimestamp)
www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.