php+mysql一般情况下存储时间都为时间戳,但实际需要的时候,我们很可能需要对时间进行修改,这就需要由时间戳转换到时间格式,再时间格式转换为时间戳,而php需要一定的时间格式才能转换成时间戳(表示从格林威治时间1970年01月01日00时00分00秒起至现在的总秒数),因此需要进行正则判断
下面贴出代码:
<?php //匹配时间格式为2012-02-16或2012-02-16 23:59:59前面为0的时候可以不写 $time = "2012-02-16 23:59:59"; $patten = "/^\d{4}[\-](0?[1-9]|1[012])[\-](0?[1-9]|[12][0-9]|3[01])(\s+(0?[0-9]|1[0-9]|2[0-3])\:(0?[0-9]|[1-5][0-9])\:(0?[0-9]|[1-5][0-9]))?$/"; if (preg_match($patten, $time)) { echo $timestro = strtotime($time); } else { echo "error"; } ?>
对该正则的分析:
/^\d{4}[\-](0?[1-9]|1[012])[\-](0?[1-9]|[12][0-9]|3[01])(\s+(0?[0-9]|[12][0-3])\:(0?[0-9]|[1-5][1-9])\:(0?[0-9]|[1-5][1-9]))?$
/是表达式开始符 最后面的/是表达式的结束符
^字符串的开始,即以***开始
$表示字符串的结尾,即表示已***结尾
|表示或者
()表示一个单元
d{4}匹配一个4位数,
(\-)匹配一个“-”号,
(0?[1-9]|1[012])匹配月份,
(0?[1-9]|[12][0-9]|3[01])匹配天,
(\s+(0?[0-9]|1[0-9]|2[0-3])\:(0?[0-9]|[1-5][0-9])\:(0?[0-9]|[1-5][0-9]))?整个匹配时分秒部分,?表示有或者没有。
最后一步就是对匹配成功的进行时间戳转换
当前转换结果为:1329407999