array_uintersect_uassoc
(PHP 5, PHP 7, PHP 8)
array_uintersect_uassoc — データと添字の比較に個別のコールバック関数を用い、 追加された添字の確認も含めて配列の共通項を計算する
説明
array_uintersect_uassoc(
array
array
callable
callable
): array
array
$array1
,array
...$arrays
,callable
$value_compare_func
,callable
$key_compare_func
): array
データと添字の比較にそれぞれ別のコールバック関数を用い、 追加された添字の確認も含めて配列の共通項を計算します。
パラメータ
array1
-
最初の配列。
arrays
-
残りの配列。
value_compare_func
-
比較関数は、最初の引数と二番目の引数の比較結果を返します。最初の引数のほうが二番目の引数より大きい場合は正の整数を、二番目の引数と等しい場合はゼロを、そして二番目の引数より小さい場合は負の整数を返す必要があります。
警告float のような 非整数 を比較関数が返すと、その返り値を内部的に int にキャストして使います。 つまり、
0.99
や0.1
といった値は整数値0
にキャストされ、 値が等しいとみなされます。警告ソートに使うコールバック関数は、任意の配列からの任意の値を、もともとの順番に関係なく、任意の順番で処理できなければいけません。なぜなら、個々の配列は、他の配列と比較する前に最初にソートされるからです。 サンプルコードは、以下のようになります:
<?php
$arrayA = ["string", 1];
$arrayB = [["value" => 1]];
// $item1 と $item2 は "string", 1, ["value" => 1] のいずれでも構いません
$compareFunc = static function ($item1, $item2) {
$value1 = is_string($item1) ? strlen($item1) : (is_array($item1) ? $item1["value"] : $item1);
$value2 = is_string($item2) ? strlen($item2) : (is_array($item2) ? $item2["value"] : $item2);
return $value1 <=> $value2;
};
?> key_compare_func
-
キーの比較用のコールバック関数。
戻り値
全ての引数に現れる
array1
の全ての値を含む配列を返します。
例
例1 array_uintersect_uassoc() の例
<?php
$array1 = array("a" => "green", "b" => "brown", "c" => "blue", "red");
$array2 = array("a" => "GREEN", "B" => "brown", "yellow", "red");
print_r(array_uintersect_uassoc($array1, $array2, "strcasecmp", "strcasecmp"));
?>
上の例の出力は以下となります。
Array ( [a] => green [b] => brown )
参考
- array_uintersect() - データの比較にコールバック関数を用い、配列の共通項を計算する
- array_intersect_assoc() - 追加された添字の確認も含めて配列の共通項を確認する
- array_intersect_uassoc() - 追加された添字の確認も含め、コールバック関数を用いて 配列の共通項を確認する
- array_uintersect_assoc() - データの比較にコールバック関数を用い、 追加された添字の確認も含めて配列の共通項を計算する
+add a note
User Contributed Notes 1 note
aidan at php dot net ¶
20 years ago
Please note, the correct function synopsis is:
array array_uintersect_uassoc ( array array1, array array2 [, array ...], callback data_compare_func, callback key_compare_func)
You may specifiy as many arrays as you like, but the last two parameters must be valid call back functions.