我正在尝试按时间值组合多个数组。 我有这样的数组。
[
{
x:"Kasa",
y:" 8",
id:6,
a:0.019444444444444
},
{
x:"Kasa",
y:" 9",
id:6,
a:0.023611111111111
},
{
x:"Kasa",
y:"10",
id:6,
a:0.018055555555556
},
{
x:"Kasa",
y:"11",
id:6,
a:0.025
},
{
x:"Kasa",
y:"12",
id:6,
a:0.0097222222222222
}
],
[
{
x:"Kasap",
y:" 8",
id:7,
a:0.0013888888888889
},
{
x:"Kasap",
y:" 9",
id:7,
a:0.015277777777778
},
{
x:"Kasap",
y:"10",
id:7,
a:0.0027777777777778
},
{
x:"Kasap",
y:"11",
id:7,
a:0.0041666666666667
},
{
x:"Kasap",
y:"12",
id:7,
a:0.019444444444444
}
]
我需要将这个2数组与y值结合起来。例如,在组合之后,数组应该是这样的。
[
{
x:"Kasa",
y:" 8",
id:6,
a:0.019444444444444
},
{
x:"Kasap",
y:" 8",
id:7,
a:0.0013888888888889
}
],
[
{
x:"Kasa",
y:"11",
id:6,
a:0.025
},
{
x:"Kasap",
y:"11",
id:7,
a:0.0041666666666667
}
],
[
{
x:"Kasa",
y:"12",
id:6,
a:0.0097222222222222
},
{
x:"Kasap",
y:"12",
id:7,
a:0.019444444444444
}
],
[
{
x:"Kasa",
y:" 9",
id:6,
a:0.023611111111111
},
{
x:"Kasap",
y:" 9",
id:7,
a:0.015277777777778
}
],
[
{
x:"Kasap",
y:"10",
id:7,
a:0.0027777777777778
},
{
x:"Kasa",
y:"10",
id:6,
a:0.018055555555556
}
]
我应该为这个案子做些什么?
答案 0 :(得分:3)
由于您正在标记此问题“Laravel”,因此您可以使用优秀的Collection类:
collect($array)->flatten(1)->groupBy('y')->toArray()
答案 1 :(得分:0)
试试这个: 我用这个数组测试了它
$array= array_merge($array1, $array2);
foreach ($array as $k => $value) {
foreach ( $value as $key => $v) {
if ($key === 'y'){
$result[$v]='';
}
}
}
foreach ($array as $k => $value) {
if ($value['y'] == key_exists($value['y'],$result)) {
$result[$value['y']][$k]= $value;
}
}
修改
<table>
<tr>
<?php
for ($j = 1; $j <= 9; ++$j) {
if ($j % 2 == 0) {
echo '<td class="pair" id="DiagP_' . $j . '">' . $j . '</td>';
}
} ?>
</tr>
</table>
答案 2 :(得分:0)
尝试在 array_merge_recursive()功能
中构建的php$array = array_merge_recursive($array1, $array2);
or make your own function (it may be faster)
function my_array_merge(&$array1, &$array2) {
$result = Array();
foreach($array1 as $key => &$value) {
$result[$key] = array_merge($value, $array2[$key]);
}
return $result;
}
$array = my_array_merge($array1, array2);
print_r($array);