


In the process of developing using PHP, we usually encounter the need to convert a two-dimensional array into a one-dimensional array. This requirement is very common in actual development. For example, we need to process data in the database. For some data that needs to be calculated, the queried two-dimensional array is usually converted into a one-dimensional array, which facilitates our calculations.
In PHP, the method of converting a two-dimensional array into a one-dimensional array is very simple and can be done using the array_column() function. Let's take a closer look at how to use the array_column() function.
Basic usage of the array_column() function
The basic syntax of the array_column() function is as follows:
array array_column( array $input, mixed $column_key [, mixed $index_key ] )
This function accepts three parameters, where the $input parameter specifies the array to be converted, the $column_key parameter specifies the column name or key name to be converted into a one-dimensional array, and the $index_key parameter is optional and is used to represent The key name in the new array. If not specified, the numeric index is used.
For example, we have a two-dimensional array as follows:
$users = array(
array('id' => 1, 'name' => 'Tom', 'age' => 20), array('id' => 2, 'name' => 'Jerry', 'age' => 18), array('id' => 3, 'name' => 'Lucy', 'age' => 22)
);
We can use the array_column() function to Convert it to a one-dimensional array:
$names = array_column($users, 'name');
The converted result is:
array('Tom' , 'Jerry', 'Lucy')
In the above example, we converted the name field in the $users array into a new one-dimensional array.
In actual development, we may need to convert multiple fields into one-dimensional arrays at the same time. In this case, we can convert multiple fields into one-dimensional arrays respectively, and then splice them together. For example, the following code will convert both the name and age fields into one-dimensional arrays:
$names = array_column($users, 'name');
$ages = array_column($users, 'age') ;
$info = array_merge($names, $ages);
The converted result is:
array('Tom', 'Jerry', 'Lucy', 20, 18, 22)
In the above example, we spliced the $name and $ages arrays together to obtain a new one-dimensional array.
Advanced usage of array_column() function
In addition to the basic usage introduced above, the array_column() function also has some advanced usage, let’s introduce them one by one below.
- Original array as index
Sometimes we need to use a field in the original array as the index of the new array. In this case, we can call array_column() function, specify the third parameter $index_key as the field name in the original array. For example, to use the id field in the above $users array as the index of the new array, you can do the following:
$users = array(
array('id' => 1, 'name' => 'Tom', 'age' => 20), array('id' => 2, 'name' => 'Jerry', 'age' => 18), array('id' => 3, 'name' => 'Lucy', 'age' => 22)
);
$names = array_column($ users, 'name', 'id');
The converted result is:
array(1 => 'Tom', 2 => 'Jerry', 3 => ; 'Lucy')
As you can see, the key name of the new array is the id field in the original array.
- Processing multi-dimensional arrays
In actual development, we may encounter situations where we need to process multi-dimensional arrays. In this case, we can use the array_map() function to convert each The two-dimensional array is converted into a one-dimensional array, and then the array_merge() function is used to splice them together to obtain a new one-dimensional array. For example:
$users = array(
array('id' => 1, 'name' => array('first' => 'Tom', 'last' => 'Smith'), 'age' => 20), array('id' => 2, 'name' => array('first' => 'Jerry', 'last' => 'Brown'), 'age' => 18), array('id' => 3, 'name' => array('first' => 'Lucy', 'last' => 'Johnson'), 'age' => 22)
);
$names = array_map(function($user) {
return $user['name']['first'] . ' ' . $user['name']['last'];
}, $users);
$ages = array_column($users, 'age');
$info = array_merge($names, $ages);
The converted result is:
array( 'Tom Smith', 'Jerry Brown', 'Lucy Johnson', 20, 18, 22)
As you can see, when we convert the name field in the $users array into a one-dimensional array, we need to use array_map( ) function, convert each two-dimensional array into a one-dimensional array, and then splice them together using the array_merge() function.
Summary
Through the introduction of this article, we can see that converting a two-dimensional array into a one-dimensional array is very easy in PHP, just use the array_column() function. If you need to convert multiple fields into a one-dimensional array, you can use the array_column() function multiple times and then splice them together. If you need to index a field in the original array, you can specify the third parameter when calling the array_column() function. If you need to process multi-dimensional arrays, you can use the array_map() function to convert each two-dimensional array to one dimension. arrays and then splice them together using the array_merge() function.
The above is the detailed content of How to convert two-dimensional array to one-dimensional array in php. 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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

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),

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

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.

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.
