繁体   English   中英

如何计算集合对象中对象的重复出现次数。 PHP /拉威尔

[英]How to count recurrence of objects in collection object. PHP/Laravel

我使用这个laravel函数来获取过去30天内创建的所有发票:

$invoice = Invoices::where('created_at', '>=', Carbon::now()->subMonth())->get();

该函数返回对象的集合,我想要的是为每个对象获取一个数组[创建日期=>当天在其中创建的位置]。

我正在阅读有关array_count_values的信息,但是该功能不适用于集合对象。

任何帮助表示赞赏。

您可能正在寻找groupBy方法。 它允许您将结果分组到一个集合的集合中。 例如:

$invoiceGroup = Invoices::where('created_at', '>=', Carbon::now()->subMonth())
    ->get()
    ->groupBy(function($invoice) {
        return $invoice->created_at->format('d-M-y');
    });

现在,所有发票均基于其created_at日期分组在一起。

foreach ($invoiceGroup as $date => $subGroup) {
    echo $date . ': ' . $subGroup->count();
}

这将回显created_at日期和该日期的发票数。 要获取单个发票:

foreach ($invoiceGroup as $date => $subGroup) {
    foreach ($subGroup as $invoice) {
        // Access individual invoices
    }
}

这是我为解决问题所做的:

foreach ($invoice as $key => $value) {
        $date = Carbon::createFromFormat('Y-m-d H:i:s', $value->created_at);
        $result[$value->quote_number] = $date->day;
    }

然后,我使用array_count_values($result)来获取所需的内容,也许有一个内置函数array_count_values($result)我的需要,这就是为什么我现在不选择它作为答案。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM