Checking for valid date input and convert appropriately

Ferrous Cranus nikos.gr33k at gmail.com
Thu Feb 21 18:08:01 EST 2013


Τη Παρασκευή, 22 Φεβρουαρίου 2013 12:03:59 π.μ. UTC+2, ο χρήστης Michael Ross έγραψε:
> 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.

i just want to check for date validity from within ha same if statemnt like i check the other variables and i tried a regualr expression just now:

if( task and ( price and price.isdigit() and price.__len__() <= 3 ) and ( date and re.search( r'(\d+) (\d+) (\d+)', date ) ) ):

Do i ahve somehting wrong in it?

will the if become true if the user enters 21 02 2013 ?



More information about the Python-list mailing list