工作中经常会遇到php获取各种时间的需要,现在特此做些总结首先需要知道的是在php中获取时间方法是date(),在php中获取时间戳方法有time()、 strtotime()下面分别说明,我来为大家科普一下关于php获取时间戳函数?下面希望有你要的答案,我们一起来看看吧!

php获取时间戳函数(以及如何拿到各种时间)

php获取时间戳函数

工作中经常会遇到php获取各种时间的需要,现在特此做些总结。首先需要知道的是在php中获取时间方法是date(),在php中获取时间戳方法有time()、 strtotime()。下面分别说明。

date()格式为:date($format, $timestamp),format为格式、timestamp为时间戳(可选)。

time()返回当前时间的 Unix 时间戳,没有参数。

strtotime($time, $now)将任何英文文本的日期时间描述解析为 Unix时间戳。$time为必填,规定要解析的时间字符串;$now用来计算返回值的时间戳,如果省略该参数,则使用当前时间。

####date()函数字符串格式中各个字母的含义:

a - “am” 或是 “pm”

A - “AM” 或是 “PM”

d - 几日,二位数字,若不足二位则前面补零; 如: “01” 至 “31”

D - 星期几,三个英文字母; 如: “Fri”

F - 月份,英文全名; 如: “January”

h - 12 小时制的小时; 如: “01” 至 “12”

H - 24 小时制的小时; 如: “00” 至 “23”

g - 12 小时制的小时,不足二位不补零; 如: “1” 至 12"

G - 24 小时制的小时,不足二位不补零; 如: “0” 至 “23”

i - 分钟; 如: “00” 至 “59”

j - 几日,二位数字,若不足二位不补零; 如: “1” 至 “31”

l - 星期几,英文全名; 如: “Friday”

m - 月份,二位数字,若不足二位则在前面补零; 如: “01” 至 “12”

n - 月份,二位数字,若不足二位则不补零; 如: “1” 至 “12”

M - 月份,三个英文字母; 如: “Jan”

s - 秒; 如: “00” 至 “59”

S - 字尾加英文序数,二个英文字母; 如: “th”,“nd”

t - 指定月份的天数; 如: “28” 至 “31”

U - 总秒数

w - 数字型的星期几,如: “0” (星期日) 至 “6” (星期六)

Y - 年,四位数字; 如: “1999”

y - 年,二位数字; 如: “99”

z - 一年中的第几天; 如: “0” 至 “365”

####strtotime($time)用法举例:

echo strtotime('2012-03-22');输出结果:1332427715(此处结果为随便写的,仅作说明使用)

echo strtotime(date('Y-d-m'));输出结果:(结合date(),结果同上)(时间日期转换为时间戳)

strtotime()还有个很强大的用法,参数可加入对于数字的操作、年月日周英文字符,示例如下:

echo date('Y-m-d H:i:s',strtotime(' 1 day'));输出结果:2012-03-23 23:30:33(会发现输出明天此时的时间)

echo date('Y-m-d H:i:s',strtotime('-1 day'));输出结果:2012-03-21 23:30:33(昨天此时的时间)

echo date('Y-m-d H:i:s',strtotime(' 1 week'));输出结果:2012-03-29 23:30:33(下个星期此时的时间)

echo date('Y-m-d H:i:s',strtotime('next Thursday'));输出结果:2012-03-29 00:00:00(下个星期四此时的时间)

echo date('Y-m-d H:i:s',strtotime('last Thursday'));输出结果:2012-03-15 00:00:00(上个星期四此时的时间)

1

2

3

4

5

6

7

8

####一些常用的格式化时间:

echo "明天凌晨的时间戳:".strtotime(date('Y-m-d',strtotime(' 1 day')));

echo"一周后:".date("Y-m-d",strtotime(" 1 week"));

echo"一周零两天四小时两秒后:".date("Y-m-d G:H:s",strtotime(" 1 week 2 days 4 hours 2 seconds"));

echo"下个星期四:".date("Y-m-d",strtotime("next Thursday"));

echo"上个周一:".date("Y-m-d",strtotime("last Monday"));

echo"一个月前:".date("Y-m-d",strtotime("last month"));

echo"一个月后:".date("Y-m-d",strtotime(" 1 month"));

echo"十年后:".date("Y-m-d",strtotime(" 10 year"));

//今天开始时间 $beginToday= date("Y-m-d H:i:s",mktime(0,0,0,date('m'),date('d'),date('Y')));

//今天结束时间 $endToday= date("Y-m-d H:i:s",mktime(0,0,0,date('m'),date('d') 1,date('Y'))-1);

//昨天开始的时间 $beginYesterday= date("Y-m-d H:i:s",mktime(0,0,0,date('m'),date('d')-1,date('Y')));

//昨天结束时间 $endYesterday= date("Y-m-d H:i:s",mktime(0,0,0,date('m'),date('d'),date('Y'))-1);

//本周开始时间 $beginThisweek = date("Y-m-d H:i:s",mktime(0, 0 , 0,date("m"),date("d")-date("w") 1,date("Y")));

//本周结束时间 $endThisweek = date("Y-m-d H:i:s",mktime(23,59,59,date("m"),date("d")-date("w") 7,date("Y")));

//上周开始的时间 $beginLastweek= date("Y-m-d H:i:s",mktime(0,0,0,date('m'),date('d')-date('w') 1-7,date('Y')));

//上周结束时间 $endLastweek= date("Y-m-d H:i:s",mktime(23,59,59,date('m'),date('d')-date('w') 7-7,date('Y')));

//本月开始时间 $beginThismonth = date("Y-m-d H:i:s",mktime(0,0,0,date('m'),1,date('Y')));

//本月结束时间 $endThismonth = date("Y-m-d H:i:s",mktime(23,59,59,date('m'),date('t'),date('Y')));

//上月开始时间 $beginLastmonth = date("Y-m-d H:i:s",mktime(0, 0 , 0,date("m")-1,1,date("Y")));

//上月结束时间 $endLastmonth = date("Y-m-d H:i:s",mktime(23,59,59,date("m") ,0,date("Y")));

//本季度开始时间 $season = ceil((date('n'))/3);

//当前是第几季度 $beginThisseason = date('Y-m-d H:i:s', mktime(0, 0, 0,$season*3-3 1,1,date('Y')));

//本季度结束时间 $endThisseason = date('Y-m-d H:i:s', mktime(23,59,59,$season*3,date('t',mktime(0, 0 , 0,$season*3,1,date("Y"))),date('Y')));

//上季度开始时间 $season1 = ceil((date('n'))/3)-1;

//上季度是第几季度 $beginLastseason = date('Y-m-d H:i:s', mktime(0, 0, 0,$season1*3-3 1,1,date('Y')));

//上季度结束时间 $endLastseason = date('Y-m-d H:i:s', mktime(23,59,59,$season1*3,date('t',mktime(0, 0 , 0,$season1*3,1,date("Y"))),date('Y')));

//本年开始时间 $beginThisyear=date("Y",time())."-1"."-1";

//本年结束时间 $endThisyear =date("Y",time())."-12"."-31";

,