Calcular python de diferença de data e hora

Estou escrevendo a função timediff para calcular a diferença de tempo (segundos) entre 2 dando a hora da data

def timediff(time1, time2):
    timeformat = '%d%b%Y:%H:%M:%S'
    #time1="01MAR2016:07:11:53"
    #time2="01MAR2016:16:28:38"

    try:
        date_object1 = datetime.strptime(time1, timeformat)
        date_object2 = datetime.strptime(time2, timeformat)
    except ValueError:
        print "time1 format: " + repr(time1)
        print "time2 format: " + repr(time2)
        raise                      

    return abs((date_object2 - date_object1).seconds)  

Parece não levar o "mês, data, ano" para o cálculo. Fornece o cálculo correto se estiver no mesmo "mês, data, ano"

>>> t1="01MAR2016:07:11:53"
>>> t2="01MAR2016:16:28:38"
>>> timediff(t1, t2)
33405

No entanto, com diferentes "mês, data, ano", dá a resposta errada. Isso calcula apenas a diferença de tempo ~ 18 horas (o que dá ~ 65k segundos)

>>> t1="02APR2016:06:43:51"
>>> t2="06APR2016:00:58:03"
>>> timediff(t1, t2)
65652

Ou 24 horas diferente, dá 0

>>> t1="01MAR2016:07:11:53"
>>> t2="02MAR2016:07:11:53"
>>> timediff(t1, t2)
0

A data e hora assume o formato de hora que eu dou

>>> t1="01MAR2016:07:11:53"
>>> t2="02MAR2016:07:11:53"
>>> datetime.strptime(t1, timeformat)
datetime.datetime(2016, 3, 1, 7, 11, 53)
>>> datetime.strptime(t2, timeformat)
datetime.datetime(2016, 3, 2, 7, 11, 53)

Estou faltando alguma coisa?

Eu tenho outra alternativa que converte data e hora em segundos. Mas ainda quero saber por que esse método não funciona.

Minha alternativa

def timediff(time1, time2):
    timeformat = '%d%b%Y:%H:%M:%S'
    t1 = datetime.strptime(time1, timeformat)
    t2 = datetime.strptime(time2, timeformat)

    return abs(time.mktime(t1.timetuple()) - time.mktime(t2.timetuple()))

Exemplo:

>>> t2
'02MAR2016:07:11:53'
>>> t1
'01MAR2016:07:11:53'
>>> timediff(t1,t2)
86400.0

questionAnswers(1)

yourAnswerToTheQuestion