Checking for valid date input and convert appropriately
Michael Ross
gmx at ross.cx
Thu Feb 21 17:03:59 EST 2013
On Thu, 21 Feb 2013 22:22:15 +0100, Ferrous Cranus <nikos.gr33k at gmail.com>
wrote:
> Τη Πέμπτη, 21 Φεβρουαρίου 2013 10:14:13 μ.μ. UTC+2, ο χρήστης MRAB
> έγραψε:
>> On 2013-02-21 19:38, Ferrous Cranus wrote:
>>
>> > import datetime from datetime
>>
>>
>>
>> Should be:
>>
>>
>>
>> from datetime import datetime
>>
>>
>>
>> >
>>
>> > try:
>>
>> > datetime.strptime( date, '%d %m %Y' )
>>
>>
>>
>> That parses the date and discards the result.
>>
>>
>>
>> > date = date.strptime( '%Y-%m-%d' )
>>
>>
>>
>> 'date' is a string, it doesn't have a 'strptime' method.
>>
>>
>>
>> When you parsed the date you got a datetime object; _that_ has the
>>
>> 'strptime' method.
>
> I don't need to store the date i just want to make sure is entered
> correctly.
> I would like to have the user type the date like
>
> 21 02 2013
> and then convert it to 2013-02-21 because thats how mysql wants the date
> in order to store it.
> Please show me how to write this.
>
> Also, can you show me how to write it that if so even if the user
> entered date is wrong it doesn't just crash the cgi-script?i know i can
> use tr: expect: but i want to avoid it, somehow i need to check the date
> in the same if statemnt like i do with the other user defined varibles
> for validity.
>
You *have* to try/expect in order to not have the script crash.
Think user typo: 21 02 2ß13
Personally, I'd use a javascript on the html so users can't POST invalid
dates.
I use mootools for that. It accepts 21/02/2013, 21-02-2013 and 21.02.13 as
input,
and you end up with 21.02.2013 posted to your cgi in any case.
Michael
More information about the Python-list
mailing list