[英]sort multidimensional array alphabetically into 2 columns
我有一个看起来像这样的数组
Array ( [0] => Array ( [make] => Alfa Romeo [id] => 2 )
[1] => Array ( [make] => Aston Martin [id] => 3 )
[2] => Array ( [make] => Audi [id] => 4 )
[3] => Array ( [make] => BMW [id] => 8 )
[4] => Array ( [make] => Caterham [id] => 9 )
)
我想将其垂直分为2列
所以看起来像这样
Alfa Romeo BMW
Aston Martin Caterham
Audi
现在,当Yii使用checkBoxList()
函数生成复选框时,它看起来像这样
Alfa Romeo Aston Martin
Audi BMW
Caterham
现在我有这个排序。 但这仅适用于一维数组
function array_chunk_vertical($data, $columns = 2) {
$n = count($data) ;
$per_column = floor($n / $columns) ;
$rest = $n % $columns ;
// The map
$per_columns = array( ) ;
for ( $i = 0 ; $i < $columns ; $i++ ) {
$per_columns[$i] = $per_column + ($i < $rest ? 1 : 0) ;
}
$tabular = array( ) ;
foreach ( $per_columns as $rows ) {
for ( $i = 0 ; $i < $rows ; $i++ ) {
$tabular[$i][ ] = array_shift($data) ;
}
}
return $tabular ;
}
现有功能并没有阻止它在n维数组上使用的功能。 实际上,您在此处显示的功能使用提供的输入即可准确提供所需的输出 。
<?php
function array_chunk_vertical($data, $columns = 2) {
$n = count($data) ;
$per_column = floor($n / $columns) ;
$rest = $n % $columns ;
// The map
$per_columns = array( ) ;
for ( $i = 0 ; $i < $columns ; $i++ ) {
$per_columns[$i] = $per_column + ($i < $rest ? 1 : 0) ;
}
$tabular = array( ) ;
foreach ( $per_columns as $rows ) {
for ( $i = 0 ; $i < $rows ; $i++ ) {
$tabular[$i][ ] = array_shift($data) ;
}
}
return $tabular ;
}
$cars = [
[ 'make' => 'Alfa Romeo', 'id' => 2 ],
[ 'make' => 'Aston Martin', 'id' => 3 ],
[ 'make' => 'Audi', 'id' => 4 ],
[ 'make' => 'BMW', 'id' => 8 ],
[ 'make' => 'Caterham', 'id' => 9 ],
];
echo '<table>';
foreach(array_chunk_vertical($cars) as $row) {
echo '<tr>';
foreach($row as $car) {
echo '<td><input type="checkbox" value="', $car['id'], '" />', $car['make'], '</td>';
}
echo '</tr>';
}
echo '</table>';
在这种情况下,您应该将数据添加到新的一维数组中。请尝试以下操作
$a = array(0 => array( 'make' => 'Alfa Romeo', 'id' => 2 ),
1 => array( 'make' => 'Aston Martin', 'id' => 3 ),
2 => array( 'make' => 'Audi', 'id' => 4 ),
3 => array( 'make' => 'BMW', 'id' => 8 ),
4 => array( 'make' => 'Caterham', 'id' => 9 )
);
$b=array();
foreach ($a as $v)
{
$b[]=$v['make'];
}
sort($b);
print_r($b);
然后,您可以使用传递新数组作为参数的工作函数。
尝试此操作,添加som条件以显示在您的两列中
<?php $sort=Array (
0 => Array ( 'make' => 'Alfa Romeo' ,'id' => 2 ),
1 => Array ( 'make' => 'Aston Martin' ,'id' => 3 ) ,
2 => Array ( 'make' => 'Audi' ,'id' => 4 ),
3 => Array ( 'make' => 'Caterham' ,'id' => 8 ),
4 => Array ( 'make' => 'BMW' , 'id' => 9 )
);
print_r($sort);
sort($sort); echo ' <br/>';
print_r($sort);
?>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.