通过php 的时间函数 mktime()获取
代码
//php获取今日开始时间戳和结束时间戳
$beginToday=mktime(0,0,0,date('m'),date('d'),date('Y'));
$endToday=mktime(0,0,0,date('m'),date('d')+1,date('Y'))-1;
//php获取昨日起始时间戳和结束时间戳
$beginYesterday=mktime(0,0,0,date('m'),date('d')-1,date('Y'));
$endYesterday=mktime(0,0,0,date('m'),date('d'),date('Y'))-1;
//php获取上周起始时间戳和结束时间戳
$beginLastweek=mktime(0,0,0,date('m'),date('d')-date('w')+1-7,date('Y'));
$endLastweek=mktime(23,59,59,date('m'),date('d')-date('w')+7-7,date('Y'));
//php获取本月起始时间戳和结束时间戳
$beginThismonth=mktime(0,0,0,date('m'),1,date('Y'));
$endThismonth=mktime(23,59,59,date('m'),date('t'),date('Y'));
php mktime()
根据给出的参数返回 Unix 时间戳。时间戳是一个长整数,包含了从 Unix 纪元(January 1 1970 00:00:00 GMT)到给定时间的秒数。
参数可以从右向左省略,任何省略的参数会被设置成本地日期和时间的当前值。
语法
mktime(hour,minute,second,month,day,year)
| 参数 | 描述 |
|---|---|
| hour | 可选。小时数。 |
| minute | 可选。分钟数。 |
| second | 可选。秒数(一分钟之内)。 |
| month | 可选。月份数。 |
| day | 可选。天数。 |
| year | 可选。年份数,可以是两位或四位数字,0-69 对应于 2000-2069,70-100 对应于 1970-2000。 |
php date()
格式化一个本地时间/日期
语法
string date ( string $format [, int $timestamp ] )
返回将整数 timestamp 按照给定的格式字串而产生的字符串。如果没有给出时间戳则使用本地当前时间。换句话说,timestamp 是可选的,默认值为 time()。
format参数
| format | 字符 | 说明 | 返回值例子 |
|---|---|---|---|
| 日 | — | — | |
| d | 月份中的第几天,有前导零的 2 位数字 | 01 到 31 | |
| D | 星期中的第几天,文本表示,3 个字母 | Mon 到 Sun | |
| j | 月份中的第几天,没有前导零 | 1 到 31 | |
| l | (“L”的小写字母) 星期几,完整的文本格式 | Sunday 到 Saturday | |
| N | ISO-8601 格式数字表示的星期中的第几天(PHP 5.1.0 新加) | 1(表示星期一)到 7(表示星期天) | |
| S | 每月天数后面的英文后缀,2 个字符 | st,nd,rd 或者 th。可以和 j 一起用 | |
| w | 星期中的第几天,数字表示 | 0(表示星期天)到 6(表示星期六) | |
| z | 年份中的第几天 | 0 到 365 | |
| 星期 | — | — | |
| W | ISO-8601 格式年份中的第几周,每周从星期一开始(PHP 4.1.0 新加的) | 例如:42(当年的第 42 周) | |
| 月 | — | — | |
| F | 月份,完整的文本格式,例如 January 或者 March | January 到 December | |
| m | 数字表示的月份,有前导零 | 01 到 12 | |
| M | 三个字母缩写表示的月份 | Jan 到 Dec | |
| n | 数字表示的月份,没有前导零 | 1 到 12 | |
| t | 指定的月份有几天 | 28 到 31 | |
| 年 | — | — | |
| L | 是否为闰年 | 如果是闰年为 1,否则为 0 | |
| o | ISO-8601 格式年份数字。这和 Y 的值相同,只除了如果 ISO 的星期数(W)属于前一年或下一年,则用那一年。(PHP 5.1.0 新加) | Examples: 1999 or 2003 | |
| Y | 4 位数字完整表示的年份 | 例如:1999 或 2003 | |
| y | 2 位数字表示的年份 | 例如:99 或 03 | |
| 时间 | — | — | |
| a | 小写的上午和下午值 | am 或 pm | |
| A | 大写的上午和下午值 | AM 或 PM | |
| B | Swatch Internet 标准时 | 000 到 999 | |
| g | 小时,12 小时格式,没有前导零 | 1 到 12 | |
| G | 小时,24 小时格式,没有前导零 | 0 到 23 | |
| h | 小时,12 小时格式,有前导零 | 01 到 12 | |
| H | 小时,24 小时格式,有前导零 | 00 到 23 | |
| i | 有前导零的分钟数 | 00 到 59> | |
| s | 秒数,有前导零 | 00 到 59> | |
| u | 毫秒 (PHP 5.2.2 新加)。需要注意的是 date() 函数总是返回 000000 因为它只接受 integer 参数, 而 DateTime::format() 才支持毫秒。 | 示例: 654321 | |
| 时区 | — | — | |
| e | 时区标识(PHP 5.1.0 新加) | 例如:UTC,GMT,Atlantic/Azores | |
| I | 是否为夏令时 | 如果是夏令时为 1,否则为 0 | |
| O | 与格林威治时间相差的小时数 | 例如:+0200 | |
| P | 与格林威治时间(GMT)的差别,小时和分钟之间有冒号分隔(PHP 5.1.3 新加) | 例如:+02:00 | |
| T | 本机所在的时区 | 例如:EST,MDT(【译者注】在 Windows 下为完整文本格式,例如“Eastern Standard Time”,中文版会显示“中国标准时间”)。 | |
| Z | 时差偏移量的秒数。UTC 西边的时区偏移量总是负的,UTC 东边的时区偏移量总是正的。 | -43200 到 43200 | |
| 完整的日期/时间 | — | — | |
| c | ISO 8601 格式的日期(PHP 5 新加) | 2004-02-12T15:19:21+00:00 | |
| r | RFC 822 格式的日期 | 例如:Thu, 21 Dec 2000 16:01:07 +0200 | |
| U | 从 Unix 纪元(January 1 1970 00:00:00 GMT)开始至今的秒数 | 参见 time() |
来源
php 获取今日、昨日、上周、本月的起始时间戳和结束时间戳的方法
PHP: mktime - Manual
PHP: date - Manual
本文介绍如何使用PHP的mktime()和date()函数来获取特定日期范围的开始和结束时间戳,包括今天、昨天、上周和本月。通过示例代码展示了不同时间范围的计算方法。

1505

被折叠的 条评论
为什么被折叠?



