php实现按时间排序_按时间排序的问题?

本文展示了如何在Python和PHP中处理不同日期格式,如'November11,2016'、'31Oct2016'等,通过`datetime`和`Carbon`库进行时间排序,实现日期字符串到时间戳的转换,确保按时间顺序排列任务列表。
摘要由CSDN通过智能技术生成

表中某时间字段有一些格式:

November 11, 2016

31 Oct 2016

2016-01-11

07 Nov 2016

能否按时间排序?

回复内容:

表中某时间字段有一些格式:

November 11, 2016

31 Oct 2016

2016-01-11

07 Nov 2016

能否按时间排序?

python3

>>> import time

>>> t=[('November 11, 2016','%B %d, %Y'),

('31 Oct 2016','%d %b %Y'),

('2016-01-11','%Y-%m-%d'),

('07 Nov 2016','%d %b %Y'),]

>>> t.sort(key=lambda d:time.mktime(time.strptime(d[0],d[1])))

>>> from pprint import pprint as pp

>>> pp(t)

[('2016-01-11', '%Y-%m-%d'),

('31 Oct 2016', '%d %b %Y'),

('07 Nov 2016', '%d %b %Y'),

('November 11, 2016', '%B %d, %Y')]

>>>

$date = [

'November 11, 2016',

'31 Oct 2016',

'2016-01-11',

'07 Nov 2016'

];

usort($date, function($a, $b){

$a = strtotime($a);

$b = strtotime($b);

if ($a == $b) {

return 0;

}

return ($a > $b) ? 1 : -1;

});

php

composer install Carbon

use Carbon\Carbon;

$date = [

new Carbon('November 11, 2016', 'Asia/Shanghai'),

new Carbon('31 Oct 2016', 'Asia/Shanghai'),

new Carbon('2016-01-11', 'Asia/Shanghai'),

new Carbon('07 Nov 2016', 'Asia/Shanghai'),

];

for ($i = 0; $i < count($date); $i++) {

for ($j = 0; $j < $i; $j++) {

if ($date[$j]->lt($date[$i]) {

$tmp = $date[$j];

$date[$j] = $date[$i];

$date[$i] = $tmp;

}

}

}

手机打的……如果有错,见谅……

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值