During the PHP development process, we often need to perform sum operations on data in arrays. For one-dimensional arrays, we can use the array_sum function to sum directly, but when the array becomes a two-dimensional array, we need some additional operations to find the sum of the specified columns.
For example, we now have a two-dimensional array that stores sales data. Each sub-array represents the sales data of a product, including product ID, sales volume, unit price and other information. We need to find the total revenue of all items, which is the sum of the product of sales volume and unit price.
So, how to implement this operation?
First, we can use the array_column function to get the array of the specified column. This function is new in the PHP5.5 version. Its syntax is: array_column ( array $input , mixed $column_key [, mixed $index_key = null ] ), where $input is the array of columns to be extracted, and $column_key is the array to be extracted. The key name or numeric index of the column. $index_key is optional and is the key name or numeric index of the column to be used as the key of the returned array.
For example, in the above two-dimensional array of sales data, we can use the following code to obtain the sales array of all products:
$sold_amount = array_column($sales_data, 'sold_amount');
Next, we can use the array_reduce function to modify the $sold_amount array Perform an accumulation operation to obtain the total sales volume. The syntax is: array_reduce ( array $array , callable $callback [, mixed $initial = null ] ), where $array is the array to be accumulated, $callback is a custom callback function, and $initial is the initial value.
For example, we can use the following code to find the sum of the sales of all products:
$total_sold_amount = array_reduce($sold_amount, function($carry, $item){ return $carry + $item; });
Next, we need to perform the same operation on the unit price array to get the sum of the unit prices of all products. Finally, we can multiply the two sums together to get the total revenue for all items.
The complete code is as follows:
$sales_data = array( array('id' => 1, 'sold_amount' => 50, 'unit_price' => 2.5), array('id' => 2, 'sold_amount' => 20, 'unit_price' => 3.2), array('id' => 3, 'sold_amount' => 100, 'unit_price' => 1.8), ); $sold_amount = array_column($sales_data, 'sold_amount'); $total_sold_amount = array_reduce($sold_amount, function($carry, $item){ return $carry + $item; }); $unit_price = array_column($sales_data, 'unit_price'); $total_unit_price = array_reduce($unit_price, function($carry, $item){ return $carry + $item; }); $total_revenue = $total_sold_amount * $total_unit_price; echo '所有商品的总收入为:' . $total_revenue;
After the above code is executed, the output: the total income of all products is: 630.
To sum up, when we need to perform a sum operation on a certain column of a two-dimensional array, we can use the array_column function to obtain the array of the specified column, and then use the array_reduce function to perform an accumulation operation on the array to obtain the The sum of the columns. Through these methods, we can process data more conveniently and improve development efficiency.
The above is the detailed content of PHP finds the sum of a column in a two-dimensional array. For more information, please follow other related articles on the PHP Chinese website!

This article explores efficient PHP array deduplication. It compares built-in functions like array_unique() with custom hashmap approaches, highlighting performance trade-offs based on array size and data type. The optimal method depends on profili

This article analyzes PHP array deduplication, highlighting performance bottlenecks of naive approaches (O(n²)). It explores efficient alternatives using array_unique() with custom functions, SplObjectStorage, and HashSet implementations, achieving

This article explores PHP array deduplication using key uniqueness. While not a direct duplicate removal method, leveraging key uniqueness allows for creating a new array with unique values by mapping values to keys, overwriting duplicates. This ap

This article details implementing message queues in PHP using RabbitMQ and Redis. It compares their architectures (AMQP vs. in-memory), features, and reliability mechanisms (confirmations, transactions, persistence). Best practices for design, error

This article examines current PHP coding standards and best practices, focusing on PSR recommendations (PSR-1, PSR-2, PSR-4, PSR-12). It emphasizes improving code readability and maintainability through consistent styling, meaningful naming, and eff

This article explores optimizing PHP array deduplication for large datasets. It examines techniques like array_unique(), array_flip(), SplObjectStorage, and pre-sorting, comparing their efficiency. For massive datasets, it suggests chunking, datab

This article details installing and troubleshooting PHP extensions, focusing on PECL. It covers installation steps (finding, downloading/compiling, enabling, restarting the server), troubleshooting techniques (checking logs, verifying installation,

This article explains PHP's Reflection API, enabling runtime inspection and manipulation of classes, methods, and properties. It details common use cases (documentation generation, ORMs, dependency injection) and cautions against performance overhea


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

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),
