Home Backend Development PHP Problem How to convert two-dimensional array to one-dimensional array in php

How to convert two-dimensional array to one-dimensional array in php

Apr 23, 2023 pm 04:47 PM

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)
Copy after login
Copy after login

);

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.

  1. 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)
Copy after login
Copy after login

);
$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.

  1. 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)
Copy after login

);
$names = array_map(function($user) {

return $user['name']['first'] . ' ' . $user['name']['last'];
Copy after login

}, $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!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PHP 8 JIT (Just-In-Time) Compilation: How it improves performance. PHP 8 JIT (Just-In-Time) Compilation: How it improves performance. Mar 25, 2025 am 10:37 AM

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

OWASP Top 10 PHP: Describe and mitigate common vulnerabilities. OWASP Top 10 PHP: Describe and mitigate common vulnerabilities. Mar 26, 2025 pm 04:13 PM

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.

PHP Secure File Uploads: Preventing file-related vulnerabilities. PHP Secure File Uploads: Preventing file-related vulnerabilities. Mar 26, 2025 pm 04:18 PM

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.

PHP Encryption: Symmetric vs. asymmetric encryption. PHP Encryption: Symmetric vs. asymmetric encryption. Mar 25, 2025 pm 03:12 PM

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.

What is the purpose of prepared statements in PHP? What is the purpose of prepared statements in PHP? Mar 20, 2025 pm 04:47 PM

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

How do you retrieve data from a database using PHP? How do you retrieve data from a database using PHP? Mar 20, 2025 pm 04:57 PM

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

PHP Authentication & Authorization: Secure implementation. PHP Authentication & Authorization: Secure implementation. Mar 25, 2025 pm 03:06 PM

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

What is the purpose of mysqli_query() and mysqli_fetch_assoc()? What is the purpose of mysqli_query() and mysqli_fetch_assoc()? Mar 20, 2025 pm 04:55 PM

The article discusses the mysqli_query() and mysqli_fetch_assoc() functions in PHP for MySQL database interactions. It explains their roles, differences, and provides a practical example of their use. The main argument focuses on the benefits of usin

See all articles