PHP multidimensional array group sum
With the continuous development of web applications, data processing and analysis are becoming more and more important. The use of multidimensional arrays is a common situation in web development. For multi-dimensional arrays in PHP, group summation is a frequently needed operation. This article will focus on the implementation method of multi-dimensional array group sum in PHP.
First, let's look at an example, assuming we have a multidimensional array containing product name, sales date and sales volume, as shown below:
$sales = array( array("product" => "A", "date" => "2022-01-01", "sales" => 100), array("product" => "B", "date" => "2022-01-02", "sales" => 200), array("product" => "C", "date" => "2022-01-03", "sales" => 250), array("product" => "B", "date" => "2022-01-04", "sales" => 150), array("product" => "A", "date" => "2022-01-05", "sales" => 300), array("product" => "C", "date" => "2022-01-06", "sales" => 400), );
We want to The sum of sales can be achieved through the following code:
<?php $sum = array(); // 定义存放结果的数组 foreach ($sales as $sale) { $product = $sale["product"]; // 获取产品名称 $salesAmt = $sale["sales"]; // 获取销售额 // 如果该产品名称不存在,则创建一个以该产品名称为键的数组元素 if (!array_key_exists($product, $sum)) { $sum[$product] = 0; } // 将销售额加入该产品名称对应的数组元素中 $sum[$product] += $salesAmt; } print_r($sum); // 输出结果 ?>
The output of the above code is as follows:
Array ( [A] => 400 [B] => 350 [C] => 650 )
The idea of code implementation is to use a foreach loop to traverse each array in the multi-dimensional array Element, get the product name and sales volume of this element. Then, by judging whether the product name already exists in the array storing the results, if not, create an array element with the product name as the key. Finally, add the sales volume to the array element corresponding to the product name. After the traversal is completed, the total sales volume corresponding to each product name can be obtained.
We can also group and sum based on multiple conditions. For example, in the above example, if you want to group and sum by product name and sales date, you can achieve it through the following code:
<?php $sum = array(); // 定义存放结果的数组 foreach ($sales as $sale) { $product = $sale["product"]; // 获取产品名称 $date = $sale["date"]; // 获取销售日期 $salesAmt = $sale["sales"]; // 获取销售额 // 如果该产品名称不存在,则创建一个以该产品名称为键的数组元素 if (!array_key_exists($product, $sum)) { $sum[$product] = array(); } // 如果该销售日期不存在,则创建一个以该销售日期为键的数组元素 if (!array_key_exists($date, $sum[$product])) { $sum[$product][$date] = 0; } // 将销售额加入该产品名称和销售日期对应的数组元素中 $sum[$product][$date] += $salesAmt; } print_r($sum); // 输出结果 ?>
The output of the above code is as follows:
Array ( [A] => Array ( [2022-01-01] => 100 [2022-01-05] => 300 ) [B] => Array ( [2022-01-02] => 200 [2022-01-04] => 150 ) [C] => Array ( [2022-01-03] => 250 [2022-01-06] => 400 ) )
What the code implements The idea is similar to the previous example, except that in the array storing the results, each array element creates an array with the sales date as the key. In this way, you can easily group and sum by product name and sales date.
To summarize, group summation of multi-dimensional arrays in PHP is a common operation. When implementing, we can use the foreach loop to traverse each array element in the array and create new array elements as needed to achieve the group summation function. Of course, for situations where the amount of data is large, we can also use advanced functions such as PHP's array_reduce() function to complete the corresponding operations and improve the execution efficiency and running speed of the code.
The above is the detailed content of PHP multidimensional array group sum. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



PHP 8's JIT compilation enhances performance by compiling frequently executed code into machine code, benefiting applications with heavy computations and reducing execution times.

The article discusses securing PHP file uploads to prevent vulnerabilities like code injection. It focuses on file type validation, secure storage, and error handling to enhance application security.

The article discusses OWASP Top 10 vulnerabilities in PHP and mitigation strategies. Key issues include injection, broken authentication, and XSS, with recommended tools for monitoring and securing PHP applications.

The article discusses symmetric and asymmetric encryption in PHP, comparing their suitability, performance, and security differences. Symmetric encryption is faster and suited for bulk data, while asymmetric is used for secure key exchange.

Article discusses retrieving data from databases using PHP, covering steps, security measures, optimization techniques, and common errors with solutions.Character count: 159

The article discusses strategies for implementing API rate limiting in PHP, including algorithms like Token Bucket and Leaky Bucket, and using libraries like symfony/rate-limiter. It also covers monitoring, dynamically adjusting rate limits, and hand

The article discusses implementing robust authentication and authorization in PHP to prevent unauthorized access, detailing best practices and recommending security-enhancing tools.

Prepared statements in PHP enhance database security and efficiency by preventing SQL injection and improving query performance through compilation and reuse.Character count: 159
