- 浏览: 13730906 次
- 性别:
- 来自: 洛杉矶
文章分类
- 全部博客 (1994)
- Php / Pear / Mysql / Node.js (378)
- Javascript /Jquery / Bootstrap / Web (435)
- Phone / IOS / Objective-C / Swift (137)
- Ubuntu / Mac / Github / Aptana / Nginx / Shell / Linux (335)
- Perl / Koha / Ruby / Markdown (8)
- Java / Jsp (12)
- Python 2 / Wxpython (25)
- Codeigniter / CakePHP (32)
- Div / Css / XML / HTML5 (179)
- WP / Joomla! / Magento / Shopify / Drupal / Moodle / Zimbra (275)
- Apache / VPN / Software (31)
- AS3.0/2.0 / Flex / Flash (45)
- Smarty (6)
- SEO (24)
- Google / Facebook / Pinterest / SNS (80)
- Tools (22)
最新评论
-
1455975567:
xuezhongyu01 写道wocan23 写道我想问下那个 ...
Mysql: LBS实现查找附近的人 (两经纬度之间的距离) -
xuezhongyu01:
wocan23 写道我想问下那个111.1是怎么得来的我也看不 ...
Mysql: LBS实现查找附近的人 (两经纬度之间的距离) -
18335864773:
试试 pageoffice 在线打开 PDF 文件吧. pag ...
jquery在线预览PDF文件,打开PDF文件 -
青春依旧:
opacity: 0.5; 个人喜欢这种方式!关于其他css特 ...
css透明度的设置 (兼容所有浏览器) -
July01:
推荐用StratoIO打印控件,浏览器和系统的兼容性都很好,而 ...
搞定网页打印自动分页问题
先来介绍几个核心函数:
mktime 函数
mktime() 函数返回一个日期的 Unix 时间戳。
参数总是表示 GMT 日期,因此 is_dst 对结果没有影响。
参数可以从右到左依次空着,空着的参数会被设为相应的当前 GMT 值。
语法
mktime(hour,minute,second,month,day,year,is_dst)
参数 描述 hour 可选。规定小时。 minute 可选。规定分钟。 second 可选。规定秒。 month 可选。规定用数字表示的月。 day 可选。规定天。 year 可选。规定年。在某些系统上,合法值介于 1901 - 2038 之间。不过在 PHP 5 中已经不存在这个限制了。 is_dst 可选。如果时间在日光节约时间(DST)期间,则设置为1,否则设置为0,若未知,则设置为-1。 自 5.1.0 起,is_dst 参数被废弃。因此应该使用新的时区处理特性。
例子 mktime() 函数对于日期运算和验证非常有用。它可以自动校正越界的输入: <?php echo(date("M-d-Y",mktime(0,0,0,12,36,2001))); echo(date("M-d-Y",mktime(0,0,0,14,1,2001))); echo(date("M-d-Y",mktime(0,0,0,1,1,2001))); echo(date("M-d-Y",mktime(0,0,0,1,1,99))); ?> 输出: Jan-05-2002 Feb-01-2002 Jan-01-2001 Jan-01-1999
strtotime 函数
strtotime() 函数将任何英文文本的日期时间描述解析为 Unix 时间戳。
语法
strtotime(time,now)
参数 描述 time 规定要解析的时间字符串。 now 用来计算返回值的时间戳。如果省略该参数,则使用当前时间。
一周之后: strtotime("+1 week") ;
一周之前: strtotime("-1 week") ;
一月之后: strtotime("+1 months") ;
一天之后: strtotime("+1 days") ;
30秒之后 strtotime( " +30 seconds " );
20分钟之后 strtotime( " +20 minutes " );
12个小时之后 strtotime( " +12 hours " );
date 函数
date() 函数格式化一个本地时间/日期。
语法
date(format,timestamp)
date_default_timezone_set 函数
date_default_timezone_set() 函数设置用在脚本中所有日期/时间函数的默认时区。
语法
date_default_timezone_set(timezone)
参数 描述 timezone 必需。时区标识符,比如 "UTC" 或 "Europe/Paris"。 合法时区的列表:http://www.php.net/manual/en/timezones.php
实例
第一种情况是没有数据库,只是得到的日期值进行比较的话,那就得完全用php的时间日期函数计算了,如下:
比如要计算2009-9-5到2009-9-18还有多少天:
<?php $startdate=strtotime("2009-9-5"); $enddate=strtotime("2009-9-18"); //上面的php时间日期函数已经把日期变成了时间戳,就是变成了秒。这样只要让两数值相减,然后把秒变成天就可以了,比较的简单,如下: $days=round(($enddate-$startdate)/3600/24) ; echo $days; //days为得到的天数; ?>
第二种 孩子的成长
<? date_default_timezone_set('Asia/Shanghai'); //以上一句为设置时区,其实不设也行,但是zde debug的时候会有提示,说什么不安全的函数…添上吧。 echo date('Y-m-d H:i:s').' 今天是'.date('Y').'年的第'.date('W').'周'; $stime='2005-11-03 10:08'; echo "<br/><br/>***自出生(<font color=blue>$stime</font>)以来…:<br/><br/>"; echo "今天是第<font color=red><b>".Lnbsp(daysofnow($stime),3)."</b></font>天<br/>"; echo "今天是第<font color=red><b>".Lnbsp(weeksofnow($stime),3)."</b></font>周<br/>"; echo "今天是第<font color=red><b>".Lnbsp(monthsofnow($stime),3)."</b></font>个月<br/>"; echo "今天是第<font color=red><b>".Lnbsp(yearsofnow($stime),3)."</b></font>年<br/>"; /* $output=sprintf(" 今天是第<font color=red><b>%03d</b></font>天<br/>今天是第< font color=red><b>%03d</b></font>周<br/>今天是第< font color=red><b>%03d</b></font>个月<br/>今天是第< font color=red><b>%03d</b></font>年<br/& gt;",daysofnow($stime),weeksofnow($stime),monthsofnow($stime),yearsofnow($stime)); echo $output; */ function weeksofnow($stime) { $ftime=strtotime($stime); $fweeks=date('w',$ftime); if ($fweeks==0) $fweeks=7; $nweeks=date('w'); if ($nweeks==0) $nweeks=7; $ftemp=strtotime(date('Y-m-d 00:00:00',$ftime))-$fweeks*60*60*24; $ntemp=strtotime(date('Y-m-d 00:00:00',time()))+(7-$nweeks)*60*60*24; //echo date('w',$ftemp)."<br/>....<br/>".date('w',$ntemp)."<br/>"; return ($ntemp-$ftemp)/60/60/24/7; } function daysofnow($stime) { $ftime=strtotime($stime); return ceil(abs((time()-$ftime)/(60*60*24))); } function monthsofnow($stime) { $ftime=strtotime($stime); $fmonth=date('m',$ftime); $fyear=date('Y',$ftime); $nmonth=date('m'); $nyear=date('Y'); $result=($nyear-$fyear)*12+$nmonth-$fmonth+1; return $result; } function yearsofnow($stime) { $ftime=strtotime($stime); $fyear=date('Y',$ftime); $nyear=date('Y'); return $nyear-$fyear+1; } // 下面的函数只是加空格用的,不是核心内容,只为美观 function Lnbsp($data,$num) { $result=trim($data); for($i=$num;$i>=strlen($data);$i--) { $result=' '.$result; } return $result; } ?>
第三种 明天,下个月和明年的日期,就可以用以下的代码:
$tomorrow = date('Y-m-d',mktime (0,0,0,date("m"),date("d")+1,date("Y"))); $nextmonth = date('Y-m',mktime (0,0,0,date("m")+1,date("d")+1,date("Y"))); $nextyear = date('Y',mktime (0,0,0,date("m"),date("d"),date("Y")+1)); echo $tomorrow.'<br/>'; echo $nextmonth.'<br/>'; echo $nextyear.'<br/>';
第四种 工作时间(刨除假日)
<? $startDate="2001-12-12"; $endDate="2002-11-1"; $holidayArr=array("05-01","05-02","10-01","10-01","10-02","10-03","10-04","10-05","01-26","01-27","01-28","01-29"); //假期日期数组,比方国庆,五一,春节等 $endWeek=2; //周末是否双休.双休为2,仅仅星期天休息为1,没有休息为0 $beginUX=strtotime($startDate); $endUX=strtotime($endDate); for($n=$beginUX;$n<=$endUX;$n=$n+86400){ $week=date("w",$n); $MonDay=date("m-d",$n); if($endWeek){//去处周末休息 if($endWeek==2){ if($week==0||$week==6) continue; } if($endWeek==1){ if($week==0) continue; } } if(in_array($MonDay,$holidayArr)) continue; $totalHour+=10;//每天工作10小时 } echo "开始日期:$startDate<BR>"; echo "结束日期:$endDate<BR>"; echo "共花了".$totalHour."小时"; ?>
第五种 mysql 处理日期 (防灌水)
// $ip = getenv('REMOTE_ADDR'); $sql = "SELECT TIME_TO_SEC(NOW())-TIME_TO_SEC(time_at) from test "; // 或者 select time_to_sec("1980-8-20 12:25:33") - time_to_sec("1997-1-23 6:04:56")
或者用
SELECT DATEDIFF('2008-12-30','2008-12-29') AS DiffDate /* 结果: DiffDate 1 */
或者
/* 假设我们有如下的表: OrderId ProductName OrderDate 1 'Computer' 2008-12-29 16:25:46.635 */ SELECT OrderId,DATE_ADD(OrderDate,INTERVAL 2 DAY) AS OrderPayDate FROM Orders /* 结果: OrderId OrderPayDate 1 2008-12-31 16:25:46.635 */
详见:http://www.w3school.com.cn/sql/func_date_format.asp
http://www.w3school.com.cn/sql/sql_dates.asp
给出秒算小时 php
<?php function transform($sec){ $output = ''; $hours = floor($sec / 3600); $remainSeconds = $sec % 3600; $minutes = floor($remainSeconds / 60); $seconds = $sec - $hours * 3600 - $minutes * 60; if($sec >= 3600){ $output .= $hours.' h / '; $output .= $minutes.' m / '; } if($sec >= 60 && $sec < 3600){ $output .= $minutes.' m / '; } return $output .= $seconds.' s '; } echo transform(3231803); ?>
帖子发表于**前 (时间戳与日期换算的应用)
<?php function units($time){ $year = floor($time / 60 / 60 / 24 / 365); $time -= $year * 60 * 60 * 24 * 365; $month = floor($time / 60 / 60 / 24 / 30); $time -= $month * 60 * 60 * 24 * 30; $week = floor($time / 60 / 60 / 24 / 7); $time -= $week * 60 * 60 * 24 * 7; $day = floor($time / 60 / 60 / 24); $time -= $day * 60 * 60 * 24; $hour = floor($time / 60 / 60); $time -= $hour * 60 * 60; $minute = floor($time / 60); $time -= $minute * 60; $second = $time; $elapse = ''; $unitArr = array('年' =>'year', '个月'=>'month', '周'=>'week', '天'=>'day', '小时'=>'hour', '分钟'=>'minute', '秒'=>'second' ); foreach ( $unitArr as $cn => $u ) { if ( $$u > 0 ) { $elapse = $$u . $cn; break; } } return $elapse; } function stamp($past){ date_default_timezone_set("America/New_York"); // 解决php5.1以上时间戳会与实际时间相差8小时,找时区请到http://www.php.net/manual/en/timezones.php $year =(int)substr($past,0,4); // 取得年份 $month =(int)substr($past,5,2); // 取得月份 $day =(int)substr($past,8,2); // 取得几号 $hour =(int)substr($past,11,2); // 取得小时 $minutes =(int)substr($past,14,2); // 取得分钟 $second =(int)substr($past,17,2); // 取得秒数 $past = mktime($hour,$minutes,$second,$month,$day,$year); $now = time(); $diff = $now - $past; return '发表于' . units($diff) . '前'; } $past = '2009-12-24 16:49:00'; // 从数据库得到日期 echo stamp($past); ?>
两个日期相差的天数
#方法一:简单方法
$olddate = '2010-02-11'; //如果要用mktime函数,则要用explode拆解日期。 $oldtime = strtotime($olddate); $passtime = time()-$oldtime; //经过的时间戳。 echo '你在网上泡了'.floor($passtime/(24*60*60)).'天了'.'<br />'; //12天。
#方法二:用减去全年天数的时间戳来获取。
$yDate=1; $yDate_Y=date('Y',time())-1; //年份-1,即去年 $yDateYMD="$yDate_Y-01-01"; $yYMD=strtotime($yDateYMD); //去年的1月1号时间戳。 $d=date('L',$yYMD)?366:365; //是否是闰年 $yYearTime=$d*24*60*60; $yYear=date('Y-m-d',time()-$yYearTime); echo "去年的今天:$yYear<br />"; //2009-02-23
#方法三:用直接截取当前日期的年份减一,但不严谨,没有考虑到闰年。
#计算60年前的今天。忽略当中经过的闰年。 $yDate_Y=$yDate_Y-59; $md=explode('-',date('Y-m-d')); $yYMD="$yDate_Y-{$md[1]}-{$md[2]}"; echo "60年前的今天:$yYMD <br />"; //1950-02-23
#方法四: 用strtotime()和 GNU日期语法---------推荐!
//3天后; //当前时间为2010-02-23 $d=strtotime('3 days'); echo '3天后'.date('Y-m-d',$d)."<br />"; //3天前: $d=strtotime('-3 days'); echo '3天前'.date('Y-m-d',$d)."<br />"; //2010-02-20 //一个月前: $d=strtotime('-1 months'); echo '一个月前'.date('Y-m-d',$d)."<br />"; //2010-01-23 //2个月后: $d=strtotime('2 months'); echo '二个月后'.date('Y-m-d',$d)."<br />"; //2010-04-23 //1年前: $d=strtotime('-1 years'); echo '1年前'.date('Y-m-d',$d)."<br />"; //2009-02-23 //2小时前: $d=strtotime('-2 hours'); echo '目前:'.date('Y-m-d H:i:s',time()).',2小时前'.date('Y-m-d H:i:s',$d)."<br />"; //目前:2010-02-23 13:38:49,2小时前2010-02-23 11:38:49
重设时间
//DateTime构造函数:o bject DateTime([string $time [,dateTimeZone $timezone]) $date = new DateTime('2010-02-23 12:26:36'); echo $date->format('Y-m-d H:i:s')."<br />"; //和date()函数相同。2010-02-23 12:26:36 //重设时间: //1、重设日期: boolean setDate(int year,int month,int day) //2、重设时间: boolean setDate(int hour,int minute[,int second]) $date->setDate(2010,2,28); echo $date->format('Y-m-d H:i:s')."<br />"; //2010-02-28 12:26:36 //日期计算,相当于上面的strtotime() $date->modify("+7 hours"); echo $date->format('Y-m-d H:i:s')."<br />"; //2010-02-28 19:26:36 $date->modify("3 days"); echo $date->format('Y-m-d H:i:s')."<br />"; //2010-03-03 19:26:36 //从上面被改过的28号开始 /*PHP5在WIN不支持money_format函数? setlocale(LC_MONETARY,'zh_CN'); echo money_format("%i",786.56);//?Fatal error: Call to undefined function money_format() */
发表评论
-
PHP: 在类(class)中加载动态函数, 变量函数或半变量函数 variable function/method
2016-09-03 07:54 7171最终实例在下方 以前 ... -
MySQL入门 (七) : 储存引擎与资料型态
2016-09-03 07:49 45531 表格与储存引擎 表格(table)是资料库中用来储存 ... -
MySQL入门 (六) : 字元集与资料库
2016-09-03 07:47 45661 Character Set与Collation 任何 ... -
MySQL入门 (五) : CRUD 与资料维护
2016-09-03 07:46 54811 取得表格资讯 1.1 DESCRIBE指令 「 ... -
MySQL入门 (四) : JOIN 与UNION 查询
2016-09-03 07:42 45001 使用多个表格 在「world」资料库的「countr ... -
PHP: 关键字global 和 超全局变量$GLOBALS的用法、解释、区别
2016-08-31 12:07 5039$GLOBALS 是一个关联数组,每一个变量为一个 ... -
MySQL入门 (三) : 运算式与函式
2016-08-31 12:01 4383运算式(expressions)已经 ... -
MySQL入门 (二) : SELECT 基础查询
2016-08-31 11:56 46811 查询资料前的基本概念 1.1 表格、纪录 ... -
MySQL入门 (一) : 资料库概论与MySQL的安装
2016-08-31 11:51 44571. 储存与管理资料 储存与管理资料一直是资讯应用上最基本 ... -
MySQL入门 (九) : 子查询 Subquery
2016-08-30 02:26 44471 一个叙述中的查询叙述 子查询(subquery)是一 ... -
PHP: 用readonly取代disabled来获取input值 submit a disabled input in a form could not ge
2016-08-30 02:21 2706The form is like below; <f ... -
PHP7革新与性能优化
2016-08-30 02:20 2146有幸参与2015年的PHP技 ... -
Mysql: 图解 inner join、left join、right join、full outer join、union、union all的区别
2016-08-18 06:03 3122对于SQL的Join,在学习起来可能是比较乱的。我们知道, ... -
Comet 反Ajax: 基于jQuery与PHP实现Ajax长轮询(LongPoll)
2016-08-18 06:00 1377传统的AJAX轮询方式,客服端以用户定义的时间间隔去服务器上 ... -
PHP:ServerPush (Comet推送) 技术的探讨
2016-08-18 05:58 1039PHP中Push(推送)技术的探讨 [http://vi ... -
PHP: 手把手编写自己的 MVC 框架实例教程
2016-08-16 05:33 18131 什么是MVC MVC模式(Model-View-Con ... -
PHP5: mysqli 插入, 查询, 更新和删除 Insert Update Delete Using mysqli (CRUD)
2016-07-29 12:55 1747原文: PHP5: mysqli 插入, 查询, 更新 ... -
MongoDB 教程索引 (附有视频)
2016-07-27 10:54 736MongoDB 教程索引 MongoDB 教程一: ... -
Node.js 模块之Nimble流程控制
2016-07-18 12:59 1080NodeJS异步的特性有时候 ... -
Node.js web应用模块之Supervisor
2016-07-18 12:56 2327在开发或调试Node.js应 ...
相关推荐
### Python 日期时间运算 在Python程序设计语言中,日期与时间的运算主要通过`datetime`模块实现。本文将详细介绍该模块中与日期时间运算相关的类及函数,并提供实际编程示例来帮助理解。 #### 1. `datetime` 模块...
1. **日期计算**:在项目中,我们经常需要计算两个日期之间的差值,或是根据当前日期向前或向后推算一定天数的日期。这在财务结算、合同到期提醒、数据分析等领域尤为重要。 2. **时区处理**:全球化的应用需要处理...
在JavaScript中,时间计算是日常开发中常见的任务,特别是在处理用户界面交互或者数据处理时。本文将详细讲解如何在JavaScript中进行日期的加减运算,以及如何返回当前时间后一个星期的日期,并确保结果以"yyyy-MM-...
Oracle数据库中的时间运算和日期时间函数是数据库管理中不可或缺的一部分,它们用于处理和操作与日期、时间和日期时间相关的数据。以下是一些关于Oracle日期时间函数的关键知识点: 1. **日期和字符转换**: - `TO...
在数据库管理中,正确理解和应用日期时间功能是至关重要的,尤其是在进行数据分析、报表生成和事务处理等场景下。本文将深入探讨Oracle数据库中日期时间的用法,通过一系列实用的函数,帮助读者掌握如何在SQL查询中...
在PHP中,可以使用`time()`函数获取当前时间的时间戳,或者`strtotime()`函数将日期字符串转换为时间戳。 计算两个时间戳之间的分钟差,可以通过以下步骤进行: 1. 获取两个时间戳,例如`$startTime`和`$endTime`。...
日期时间间隔计算是编程领域中常见的一种需求,尤其在数据分析、日程管理或者任何与时间相关的应用程序中。这个话题涉及到的主要知识点包括日期处理、时间间隔计算以及可能的编程语言实现。 1. **日期处理**:在...
一个计算当前时间与停留时间的js,时间格式可以选择到:年月日时分秒星期, 计算时间间隔的js可以精确到毫秒
(4) 编写时间和日期的派生类CDati,完成日期与时间的联合设置、运算、比较等功能,要求该派生类可以完成:日期时间加天数或时间等于新的日期时间,日期时间减天数或等于新的日期时间,两个日期时间相减等于天数或...
获得当前日期时间函数 MySQL 中有多种方式可以获得当前日期和时间,包括 now()、current_timestamp()、localtime()、localtimestamp() 等函数。其中,now() 函数是最常用的函数,用于获取当前的日期和时间。当前...
MATLAB程序计算两个日期之间的总天数
标签“c# 时间计算”表明我们可能还会涉及更复杂的时间运算,例如计算两个日期之间的闰年数、工作日数,或者处理时区转换。对于时区转换,C#的DateTimeOffset类型非常有用,因为它包含了日期、时间和相应的时区信息...
代码中包含通过逆波兰式php实现的计算四则运算表达式的方法,比如计算(103*(12/321+7)+3)*45的结果,网上常用的四则运算函数或者不能支持多位运算,或者不能支持括号,或者只有逆波兰式的实现。
1. **获取当前日期时间** ```csharp System.DateTime currentTime = System.DateTime.Now; ``` 这行代码创建了一个DateTime类型的变量`currentTime`,并将其设置为当前系统的日期和时间。 2. **取当前年、月、...
### CTime计算时间差 在C++编程语言中,处理时间相关的操作是非常常见的...这对于开发需要处理日期时间的应用程序来说是一项非常实用的功能。当然,在实际项目中还需要根据具体需求对这些功能进行更深入的研究和扩展。
DATE类型是整数,可以参与算术运算,如计算平均值或进行日期的加减操作。同时,GBase提供了丰富的日期处理函数,方便对DATE值进行处理。DATE格式可以根据用户需求进行定制,例如通过GL_DATE环境变量设定日期格式。 ...
使用位运算计算LOG2 LOG2是数学中一个常用的函数,用于计算一个数字的对数。然而,在计算机科学中,我们更关心的是如何使用位运算来计算LOG2。位运算是一种快速且高效的运算方法,可以用于加速很多复杂的操作。下面...
时间日期计算器是一个实用工具,它允许用户进行日期和时间的运算,例如计算两个日期之间的差值,或者根据已知的间隔反推日期。这种计算器通常包含以下功能: 1. **日期和时间输入**:用户可以输入或选择起始和结束...
例如,我们可以用`DateTime.Now`获取当前日期和时间,`DateTime.Today`获取当前日期,不包含时间部分。 ### 1. 计算一个月的天数 要计算特定月份的天数,我们可以利用`DateTime.DaysInMonth`方法。这个方法接受...
5. **编程访问**:在代码中,你可以通过`dateTimePicker1.Value`来获取用户选定的日期和时间,它是一个`DateTime`对象,可以进行各种日期和时间运算。 6. **自定义格式**:如果你需要自定义日期和时间的显示格式,...