- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章yii 框架实现按天,月,年,自定义时间段统计数据的方法分析由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
本文实例讲述了yii 框架实现按天,月,年,自定义时间段统计数据的方法。分享给大家供大家参考,具体如下:
天(day): 格式Y-m-d 。
月(month):格式Y-m 。
年(year):格式Y 。
时间段(range): 格式Y-m-d 。
首先计算时间 。
天0-23小时 。
1
|
$rangeTime
= range(0, 23);
|
月:1-月底 。
1
2
3
4
|
// $days = cal_days_in_month(CAL_GREGORIAN, $month, $year);
$days
=
date
(
"t"
,
strtotime
(
$year
.
'-'
.
$month
));
// 生成1-days的天
$rangeTime
= range(1,
$days
);
|
年:1-12月 。
1
|
$rangeTime
= range(1, 12);
|
时间段;开始时间-结束时间 。
1
2
3
4
5
6
7
8
9
10
|
$stimestamp
=
strtotime
(
$time
);
$etimestamp
=
strtotime
(
$time2
);
// 计算日期段内有多少天
$days
= (
$etimestamp
-
$stimestamp
) / 86400 + 1;
// 保存每天日期
for
(
$i
= 0;
$i
<
$days
;
$i
++){
$newTimeStamp
=
$stimestamp
+ (86400 *
$i
);
$rangeTime
[] =
date
(
'Y-m-d'
,
$newTimeStamp
);
$labels
[] =
date
(
'd'
,
$newTimeStamp
) . Yii::t(
'backend'
,
'day'
);
}
|
封装一下 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
/**
* 获取label和时间段
* type: day, month, year, range
* time: 日期; day为具体的天y-m-d, month为具体的月y-m, year为具体的年y
* time2 日期, 时间段的第二个时间
*/
public
function
getLabelAndRangeTime(
$type
,
$time
,
$time2
) {
if
(
empty
(
$time
)) {
$time
=
date
(
'Y-m-d'
, time());
}
$labels
= [];
$rangeTime
= [];
if
(
$type
==
'day'
) {
// 生成1-24小时
$rangeTime
= range(0, 23);
foreach
(
$rangeTime
as
$key
=>
$val
) {
$label
=
$val
. Yii::t(
'backend'
,
'hour'
);
$labels
[] =
$label
;
}
}
else
if
(
$type
==
'month'
) {
$dateArr
=
explode
(
'-'
,
$time
);
if
(
count
(
$dateArr
> 1)) {
$year
=
$dateArr
[0];
$month
=
$dateArr
[1];
$time
=
$year
;
$time2
=
$month
;
// 获取当前年月的天数
// $days = cal_days_in_month(CAL_GREGORIAN, $month, $year);
$days
=
date
(
"t"
,
strtotime
(
$year
.
'-'
.
$month
));
// 生成1-days的天
$rangeTime
= range(1,
$days
);
foreach
(
$rangeTime
as
$key
=>
$val
) {
$label
=
$val
. Yii::t(
'backend'
,
'day'
);
$labels
[] =
$label
;
}
}
}
else
if
(
$type
==
'year'
) {
// 生成1-12月
$rangeTime
= range(1, 12);
foreach
(
$rangeTime
as
$key
=>
$val
) {
$label
=
$val
. Yii::t(
'backend'
,
'month'
);
$labels
[] =
$label
;
}
}
else
if
(
$type
==
'range'
) {
$stimestamp
=
strtotime
(
$time
);
$etimestamp
=
strtotime
(
$time2
);
// 计算日期段内有多少天
$days
= (
$etimestamp
-
$stimestamp
) / 86400 + 1;
// 保存每天日期
for
(
$i
= 0;
$i
<
$days
;
$i
++){
$newTimeStamp
=
$stimestamp
+ (86400 *
$i
);
$rangeTime
[] =
date
(
'Y-m-d'
,
$newTimeStamp
);
$labels
[] =
date
(
'd'
,
$newTimeStamp
) . Yii::t(
'backend'
,
'day'
);
}
}
return
[
'type'
=>
$type
,
'time'
=>
$time
,
'time2'
=>
$time2
,
'rangeTime'
=>
$rangeTime
,
'labels'
=>
$labels
];
}
|
然后查询数据库 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
$query
= Order::find();
if
(
$type
==
'day'
) {
$query
=
$query
->select([
'FROM_UNIXTIME(pay_at,"%Y-%m-%d %H") as char_time'
,
'COUNT(id) as total_order'
,
'SUM(pay_amount) as total_order_amount'
])
->where([
'FROM_UNIXTIME(pay_at,"%Y-%m-%d")'
=>
$time
]);
}
else
if
(
$type
==
'month'
) {
$query
=
$query
->select([
'FROM_UNIXTIME(pay_at,"%Y-%m-%d") as char_time'
,
'COUNT(id) as total_order'
,
'SUM(pay_amount) as total_order_amount'
])
->where([
'FROM_UNIXTIME(pay_at,"%Y-%m")'
=> (
$time
.
'-'
.
$time2
)]);
}
else
if
(
$type
==
'year'
) {
$query
=
$query
->select([
'FROM_UNIXTIME(pay_at,"%Y-%m") as char_time'
,
'COUNT(id) as total_order'
,
'SUM(pay_amount) as total_order_amount'
])
->where([
'FROM_UNIXTIME(pay_at,"%Y")'
=>
$time
]);
}
else
if
(
$type
==
'range'
) {
$query
=
$query
->select([
'FROM_UNIXTIME(pay_at,"%Y-%m-%d") as char_time'
,
'COUNT(id) as total_order'
,
'SUM(pay_amount) as total_order_amount'
])
->where([
'between'
,
'FROM_UNIXTIME(pay_at,"%Y-%m-%d")'
,
$time
,
$time2
]);
}
$data
=
$query
->andWhere([
'pay_status'
=> 2])->groupBy(
'char_time'
)->all();
|
按时间排列下 。
1
2
3
4
5
6
|
$dataArr
= [];
foreach
(
$data
as
$allKey
=>
$allVal
) {
$dataArr
[
$allVal
->char_time][
'char_time'
] =
$allVal
->char_time;
$dataArr
[
$allVal
->char_time][
'total_order'
] =
$allVal
->total_order;
$dataArr
[
$allVal
->char_time][
'total_order_amount'
] =
bcdiv
(
$allVal
->total_order_amount, 100, 2);
}
|
再按时间获取对应数据 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
foreach
(
$rangeTime
as
$key
=>
$val
) {
if
(
$type
==
'range'
) {
if
(
array_key_exists
(
$val
,
$dataArr
)) {
$charCountDatas
[] =
$dataArr
[
$val
][
'total_order'
];
$charAmountDatas
[] =
$dataArr
[
$val
][
'total_order_amount'
];
}
else
{
$charCountDatas
[] = 0;
$charAmountDatas
[] = 0;
}
}
else
{
$theNow
=
strlen
(
$val
) == 2 ?
$val
:
'0'
.
$val
;
if
(
$type
==
'day'
) {
$theTime
=
$time
.
' '
.
$theNow
;
}
else
if
(
$type
==
'month'
) {
$theTime
=
$time
.
'-'
.
$time2
.
'-'
.
$theNow
;
}
else
if
(
$type
==
'year'
) {
$theTime
=
$time
.
'-'
.
$theNow
;
}
if
(
array_key_exists
(
$theTime
,
$dataArr
)) {
$charCountDatas
[] =
$dataArr
[
$theTime
][
'total_order'
];
$charAmountDatas
[] =
$dataArr
[
$theTime
][
'total_order_amount'
];
}
else
{
$charCountDatas
[] = 0;
$charAmountDatas
[] = 0;
}
}
}
|
封装下 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
/**
* 时间段内支付订单量及金额
* type 类型: day, month, year
* time: 时间, day: 选择的时间; month: 表示年;year: 表示年; range: 第一个时间
* time2: 时间: day: ''; month: 表示月;year: ''; range: 第二个时间
* rangeTime 时间段 day: 1-24小时; month: 1-30天; year:1-12月,range: time和time2之间的天
*/
public
function
getDayOrderPayChar(
$type
,
$time
,
$time2
,
$rangeTime
) {
$query
= Order::find();
if
(
$type
==
'day'
) {
$query
=
$query
->select([
'FROM_UNIXTIME(pay_at,"%Y-%m-%d %H") as char_time'
,
'COUNT(id) as total_order'
,
'SUM(pay_amount) as total_order_amount'
])
->where([
'FROM_UNIXTIME(pay_at,"%Y-%m-%d")'
=>
$time
]);
}
else
if
(
$type
==
'month'
) {
$query
=
$query
->select([
'FROM_UNIXTIME(pay_at,"%Y-%m-%d") as char_time'
,
'COUNT(id) as total_order'
,
'SUM(pay_amount) as total_order_amount'
])
->where([
'FROM_UNIXTIME(pay_at,"%Y-%m")'
=> (
$time
.
'-'
.
$time2
)]);
}
else
if
(
$type
==
'year'
) {
$query
=
$query
->select([
'FROM_UNIXTIME(pay_at,"%Y-%m") as char_time'
,
'COUNT(id) as total_order'
,
'SUM(pay_amount) as total_order_amount'
])
->where([
'FROM_UNIXTIME(pay_at,"%Y")'
=>
$time
]);
}
else
if
(
$type
==
'range'
) {
$query
=
$query
->select([
'FROM_UNIXTIME(pay_at,"%Y-%m-%d") as char_time'
,
'COUNT(id) as total_order'
,
'SUM(pay_amount) as total_order_amount'
])
->where([
'>='
,
'FROM_UNIXTIME(pay_at,"%Y-%m-%d")'
,
$time
])
->andWhere([
'<='
,
'FROM_UNIXTIME(pay_at,"%Y-%m-%d")'
,
$time2
]);
}
$data
=
$query
->andWhere([
'pay_status'
=> 2])->groupBy(
'char_time'
)->all();
$dataArr
= [];
foreach
(
$data
as
$allKey
=>
$allVal
) {
$dataArr
[
$allVal
->char_time][
'char_time'
] =
$allVal
->char_time;
$dataArr
[
$allVal
->char_time][
'total_order'
] =
$allVal
->total_order;
$dataArr
[
$allVal
->char_time][
'total_order_amount'
] =
bcdiv
(
$allVal
->total_order_amount, 100, 2);
}
$charCountDatas
= [];
$charAmountDatas
= [];
foreach
(
$rangeTime
as
$key
=>
$val
) {
if
(
$type
==
'range'
) {
if
(
array_key_exists
(
$val
,
$dataArr
)) {
$charCountDatas
[] =
$dataArr
[
$val
][
'total_order'
];
$charAmountDatas
[] =
$dataArr
[
$val
][
'total_order_amount'
];
}
else
{
$charCountDatas
[] = 0;
$charAmountDatas
[] = 0;
}
}
else
{
$theNow
=
strlen
(
$val
) == 2 ?
$val
:
'0'
.
$val
;
if
(
$type
==
'day'
) {
$theTime
=
$time
.
' '
.
$theNow
;
}
else
if
(
$type
==
'month'
) {
$theTime
=
$time
.
'-'
.
$time2
.
'-'
.
$theNow
;
}
else
if
(
$type
==
'year'
) {
$theTime
=
$time
.
'-'
.
$theNow
;
}
if
(
array_key_exists
(
$theTime
,
$dataArr
)) {
$charCountDatas
[] =
$dataArr
[
$theTime
][
'total_order'
];
$charAmountDatas
[] =
$dataArr
[
$theTime
][
'total_order_amount'
];
}
else
{
$charCountDatas
[] = 0;
$charAmountDatas
[] = 0;
}
}
}
$res
= [
'count'
=> [
'name'
=> Yii::t(
'backend'
,
'hour_order_pay_count_title'
),
'color'
=>
'#99CC33'
,
'charData'
=>
$charCountDatas
],
'amount'
=> [
'name'
=> Yii::t(
'backend'
,
'hour_order_pay_amount_title'
),
'color'
=>
'#99CC33'
,
'charData'
=>
$charAmountDatas
]
];
return
$res
;
}
|
前端 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
<div
class
=
"clearfix dashboard-time-select"
>
<div
class
=
"time-select"
>
<div
class
=
"row"
>
<div
class
=
"col-lg-2 col-md-2 col-sm-2"
>
<?= Html::dropDownList(
'day_type'
,
$type
, [
'day'
=> Yii::t(
'backend'
,
'day'
),
'month'
=> Yii::t(
'backend'
,
'month'
),
'year'
=> Yii::t(
'backend'
,
'year'
),
'range'
=> Yii::t(
'backend'
,
'range_time'
)], [
'class'
=>
'type dashboard-time-type'
]) ?>
</div>
<div
class
=
"col-lg-7 col-md-7 col-sm-7"
>
<div
class
=
"dashboard-time-box"
>
<div
class
=
"dashboard-time-picker dashboard-time-day <?= ($type == 'day') ? '' : 'hide' ;?>"
>
<?= DateTimePicker::widget([
'name'
=>
'time'
,
'value'
=> (!
empty
(
$time
) &&
$type
==
'day'
) ?
$time
:
''
,
'options'
=> [
'placeholder'
=> Yii::t(
'backend'
,
'date'
),
'autocomplete'
=>
'off'
,
'class'
=>
'time'
],
'removeButton'
=> false,
'pluginOptions'
=> [
'format'
=>
'yyyy-mm-dd'
,
'startView'
=>
'month'
,
'minView'
=>
'month'
,
'maxView'
=>
'month'
,
'autoclose'
=> true
]
]) ?>
</div>
<div
class
=
"dashboard-time-picker dashboard-time-month <?= ($type == 'month') ? '' : 'hide' ;?>"
>
<?= DateTimePicker::widget([
'name'
=>
'time'
,
'value'
=> (!
empty
(
$time
) &&
$type
==
'month'
) ?
$time
:
''
,
'options'
=> [
'placeholder'
=> Yii::t(
'backend'
,
'date'
),
'autocomplete'
=>
'off'
,
'class'
=>
'time'
],
'removeButton'
=> false,
'pluginOptions'
=> [
'format'
=>
'yyyy-mm'
,
'startView'
=>
'year'
,
'minView'
=>
'year'
,
'maxView'
=>
'year'
,
'autoclose'
=> true
]
]) ?>
</div>
<div
class
=
"dashboard-time-picker dashboard-time-year <?= ($type == 'year') ? '' : 'hide' ;?>"
>
<?= DateTimePicker::widget([
'name'
=>
'time'
,
'value'
=> (!
empty
(
$time
) &&
$type
==
'year'
) ?
$time
:
''
,
'options'
=> [
'placeholder'
=> Yii::t(
'backend'
,
'date'
),
'autocomplete'
=>
'off'
,
'class'
=>
'time'
],
'removeButton'
=> false,
'pluginOptions'
=> [
'format'
=>
'yyyy'
,
'startView'
=>
'decade'
,
'minView'
=>
'decade'
,
'maxView'
=>
'decade'
,
'autoclose'
=> true
]
]) ?>
</div>
<div
class
=
"dashboard-time-picker dashboard-time-range <?= ($type == 'range') ? '' : 'hide' ;?>"
>
<div
class
=
"row"
>
<div
class
=
"col-lg-6 col-md-6 col-sm-6 range-start"
>
<?= DateTimePicker::widget([
'name'
=>
'time'
,
'value'
=> (!
empty
(
$time
) &&
$type
==
'range'
) ?
$time
:
''
,
'options'
=> [
'placeholder'
=> Yii::t(
'backend'
,
'date'
),
'autocomplete'
=>
'off'
,
'class'
=>
'time time2'
],
'removeButton'
=> false,
'pluginOptions'
=> [
'format'
=>
'yyyy-mm-dd'
,
'startView'
=>
'month'
,
'minView'
=>
'month'
,
'maxView'
=>
'month'
,
'autoclose'
=> true
]
]) ?>
</div>
<div
class
=
"col-lg-6 col-md-6 col-sm-6 range-end"
>
<?= DateTimePicker::widget([
'name'
=>
'time2'
,
'value'
=> (!
empty
(
$time2
) &&
$type
==
'range'
) ?
$time2
:
''
,
'options'
=> [
'placeholder'
=> Yii::t(
'backend'
,
'date'
),
'autocomplete'
=>
'off'
,
'class'
=>
'time time2'
],
'removeButton'
=> false,
'pluginOptions'
=> [
'format'
=>
'yyyy-mm-dd'
,
'startView'
=>
'month'
,
'minView'
=>
'month'
,
'maxView'
=>
'month'
,
'autoclose'
=> true
]
]) ?>
</div>
</div>
</div>
</div>
</div>
<div
class
=
"col-lg-2 col-md-2 col-sm-2"
>
<?= Html::button(Yii::t(
'backend'
,
'sure'
), [
'class'
=>
'btn btn-success btn-dashboard-time'
,
'data-url'
=>
$url
]) ?>
</div>
</div>
</div>
</div>
|
确认按钮 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
$(
'.dashboard-time-select .btn-dashboard-time'
).click(
function
() {
var
url = $(
this
).attr(
'data-url'
);
var
timeSelect = $(
this
).parent().parent();
var
type = timeSelect.find(
'.type'
).val();
var
time =
''
;
var
time2 =
''
;
if
(type ==
'day'
) {
time = timeSelect.find(
'.dashboard-time-day input'
).val();
}
else
if
(type ==
'month'
) {
time = timeSelect.find(
'.dashboard-time-month input'
).val();
}
else
if
(type ==
'year'
) {
time = timeSelect.find(
'.dashboard-time-year input'
).val();
}
else
if
(type ==
'range'
) {
time = timeSelect.find(
'.dashboard-time-range .range-start input'
).val();
time2 = timeSelect.find(
'.dashboard-time-range .range-end input'
).val();
}
window.location.href = baseBackend +
'/'
+ url +
'?type='
+ type +
'&time='
+ time +
'&time2='
+ time2
})
$(
'.dashboard-time-select .dashboard-time-type'
).change(
function
() {
var
type = $(
this
).val();
$(
'.dashboard-time-select .dashboard-time-picker'
).addClass(
'hide'
);
$(
'.dashboard-time-select .dashboard-time-'
+ type).removeClass(
'hide'
);
})
|
。
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助.
原文链接:https://blog.csdn.net/tang05709/article/details/103803752 。
最后此篇关于yii 框架实现按天,月,年,自定义时间段统计数据的方法分析的文章就讲到这里了,如果你想了解更多关于yii 框架实现按天,月,年,自定义时间段统计数据的方法分析的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
好的,所以我编辑了以下... 只需将以下内容放入我的 custom.css #rt-utility .rt-block {CODE HERE} 但是当我尝试改变... 与 #rt-sideslid
在表格 View 中,我有一个自定义单元格(在界面生成器中高度为 500)。在该单元格中,我有一个 Collection View ,我按 (10,10,10,10) 固定到边缘。但是在 tablev
对于我的无能,我很抱歉,但总的来说,我对 Cocoa、Swift 和面向对象编程还很陌生。我的主要来源是《Cocoa Programming for OS X》(第 5 版),以及 Apple 的充满
我正在使用 meta-tegra 为我的 NVIDIA Jetson Nano 构建自定义图像。我需要 PyTorch,但没有它的配方。我在设备上构建了 PyTorch,并将其打包到设备上的轮子中。现
在 jquery 中使用 $.POST 和 $.GET 时,有没有办法将自定义变量添加到 URL 并发送它们?我尝试了以下方法: $.ajax({type:"POST", url:"file.php?
Traefik 已经默认实现了很多中间件,可以满足大部分我们日常的需求,但是在实际工作中,用户仍然还是有自定义中间件的需求,为解决这个问题,官方推出了一个 Traefik Pilot[1] 的功
我想让我的 CustomTextInputLayout 将 Widget.MaterialComponents.TextInputLayout.OutlinedBox 作为默认样式,无需在 XML 中
我在 ~/.emacs 中有以下自定义函数: (defun xi-rgrep (term) (grep-compute-defaults) (interactive "sSearch Te
我有下表: 考虑到每个月的权重,我的目标是在 5 个月内分散 10,000 个单位。与 10,000 相邻的行是我最好的尝试(我在这上面花了几个小时)。黄色是我所追求的。 我试图用来计算的逻辑如下:计
我的表单中有一个字段,它是文件类型。当用户点击保存图标时,我想自然地将文件上传到服务器并将文件名保存在数据库中。我尝试通过回显文件名来测试它,但它似乎不起作用。另外,如何将文件名添加到数据库中?是在模
我有一个 python 脚本来发送电子邮件,它工作得很好,但问题是当我检查我的电子邮件收件箱时。 我希望该用户名是自定义用户名,而不是整个电子邮件地址。 最佳答案 发件人地址应该使用的格式是: You
我想减小 ggcorrplot 中标记的大小,并减少文本和绘图之间的空间。 library(ggcorrplot) data(mtcars) corr <- round(cor(mtcars), 1)
GTK+ noob 问题在这里: 是否可以自定义 GtkFileChooserButton 或 GtkFileChooserDialog 以删除“位置”部分(左侧)和顶部的“位置”输入框? 我实际上要
我正在尝试在主页上使用 ajax 在 magento 中使用 ajax 显示流行的产品列表,我可以为 5 或“N”个产品执行此操作,但我想要的是将分页工具栏与结果集一起添加. 这是我添加的以显示流行产
我正在尝试使用 PasswordResetForm 内置函数。 由于我想要自定义表单字段,因此我编写了自己的表单: class FpasswordForm(PasswordResetForm):
据我了解,新的 Angular 7 提供了拖放功能。我搜索了有关 DnD 的 Tree 组件,但没有找到与树相关的内容。 我在 Stackblitz 上找到的一个工作示例.对比drag'ndrop功能
我必须开发一个自定义选项卡控件并决定使用 WPF/XAML 创建它,因为我无论如何都打算学习它。完成后应该是这样的: 到目前为止,我取得了很好的进展,但还有两个问题: 只有第一个/最后一个标签项应该有
我要定制xtable用于导出到 LaTeX。我知道有些问题是关于 xtable在这里,但我找不到我要找的具体东西。 以下是我的表的外观示例: my.table <- data.frame(Specif
用ejs在这里显示日期 它给我结果 Tue Feb 02 2016 16:02:24 GMT+0530 (IST) 但是我需要表现为 19th January, 2016 如何在ejs中执行此操作?
我想问在 JavaFX 中使用自定义对象制作 ListView 的最佳方法,我想要一个每个项目如下所示的列表: 我搜了一下,发现大部分人都是用细胞工厂的方法来做的。有没有其他办法?例如使用客户 fxm
我是一名优秀的程序员,十分优秀!