As I was writing a for loop earlier today, I thought that there must be a neater way of doing this… so I figured I’d ask. I looked briefly for a duplicate question but didn’t see anything obvious.
The Problem:
Given N arrays of length M, turn them into a M-row by N-column 2D array
Example:
$id = [1,5,2,8,6]
$name = [a,b,c,d,e]
$result = [[1,a],
[5,b],
[2,c],
[8,d],
[6,e]]
My Solution:
Pretty straight forward and probably not optimal, but it does work:
<?php
// $row is returned from a DB query
// $row['<var>'] is a comma separated string of values
$categories = array();
$ids = explode(",", $row['ids']);
$names = explode(",", $row['names']);
$titles = explode(",", $row['titles']);
for($i = 0; $i < count($ids); $i++) {
$categories[] = array("id" => $ids[$i],
"name" => $names[$i],
"title" => $titles[$i]);
}
?>
note: I didn’t put the name => value bit in the spec, but it’d be awesome if there was some way to keep that as well.
Maybe this? Not sure if it’s more efficient but it’s definitely cleaner.
Just did a quick simple benchmark for the 4 results on this page and got the following: