Dans un logiciel, je fusionne deux tableaux avec array_merge
une fonction. Mais je dois ajouter le même tableau (avec les mêmes clés, bien sûr) à un tableau existant.
Le problème:
$A = array('a' => 1, 'b' => 2, 'c' => 3);
$B = array('c' => 4, 'd'=> 5);
array_merge($A, $B);
// result
[a] => 1 [b] => 2 [c] => 4 [d] => 5
Comme tu vois, 'c' => 3
Est manqué.
Alors, comment puis-je fusionner tous avec les mêmes clés?
Vous devez utiliser array_merge_recursive
au lieu de array_merge
. Bien sûr, il ne peut y avoir qu'une seule clé égale à 'c'
dans le tableau, mais la valeur associée sera un tableau contenant à la fois 3
et 4
.
Essayez avec array_merge_recursive
$A = array('a' => 1, 'b' => 2, 'c' => 3);
$B = array('c' => 4, 'd'=> 5);
$c = array_merge_recursive($A,$B);
echo "<pre>";
print_r($c);
echo "</pre>";
reviendra
Array
(
[a] => 1
[b] => 2
[c] => Array
(
[0] => 3
[1] => 4
)
[d] => 5
)
$arr1 = array(
"0" => array("fid" => 1, "tid" => 1, "name" => "Melon"),
"1" => array("fid" => 1, "tid" => 4, "name" => "Tansuozhe"),
"2" => array("fid" => 1, "tid" => 6, "name" => "Chao"),
"3" => array("fid" => 1, "tid" => 7, "name" => "Xi"),
"4" => array("fid" => 2, "tid" => 9, "name" => "Xigua")
);
si vous souhaitez convertir ce tableau comme suit:
$arr2 = array(
"0" => array(
"0" => array("fid" => 1, "tid" => 1, "name" => "Melon"),
"1" => array("fid" => 1, "tid" => 4, "name" => "Tansuozhe"),
"2" => array("fid" => 1, "tid" => 6, "name" => "Chao"),
"3" => array("fid" => 1, "tid" => 7, "name" => "Xi")
),
"1" => array(
"0" =>array("fid" => 2, "tid" => 9, "name" => "Xigua")
)
);
donc, ma réponse sera comme ceci:
$outer_array = array();
$unique_array = array();
foreach($arr1 as $key => $value)
{
$inner_array = array();
$fid_value = $value['fid'];
if(!in_array($value['fid'], $unique_array))
{
array_Push($unique_array, $fid_value);
unset($value['fid']);
array_Push($inner_array, $value);
$outer_array[$fid_value] = $inner_array;
}else{
unset($value['fid']);
array_Push($outer_array[$fid_value], $value);
}
}
var_dump(array_values($outer_array));
espérons que cette réponse aidera quelqu'un à un moment donné.
$A = array('a' => 1, 'b' => 2, 'c' => 3);
$B = array('c' => 4, 'd'=> 5);
$C = array_merge_recursive($A, $B);
$aWhere = array();
foreach ($C as $k=>$v) {
if (is_array($v)) {
$aWhere[] = $k . ' in ('.implode(', ',$v).')';
}
else {
$aWhere[] = $k . ' = ' . $v;
}
}
$where = implode(' AND ', $aWhere);
echo $where;
Je viens d'écrire cette fonction, elle devrait faire l'affaire pour vous, mais elle reste jointe
public function mergePerKey($array1,$array2)
{
$mergedArray = [];
foreach ($array1 as $key => $value)
{
if(isset($array2[$key]))
{
$mergedArray[$value] = null;
continue;
}
$mergedArray[$value] = $array2[$key];
}
return $mergedArray;
}
Deux entrées dans un tableau ne peuvent pas partager une clé, vous devrez changer la clé du doublon
Essaye ça:
$array_one = $_POST['ratio_type'];
$array_two = $_POST['ratio_type'];
$array_three = $_POST['ratio_type'];
$array_four = $_POST['ratio_type'];
$array_five = $_POST['ratio_type'];
$array_six = $_POST['ratio_type'];
$array_seven = $_POST['ratio_type'];
$array_eight = $_POST['ratio_type'];
$all_array_elements = array_merge_recursive(
$array_one,
$array_two,
$array_three,
$aray_four,
$array_five,
$array_six,
$array_seven,
$array_eight
);
print_r($all_array_elements, 1);
foreach ($all_array_elements as $key => $value) {
echo $key.'-'.$value;
}