1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
<?php
class ArrayUtil
{
/**
* Take an array of arrays, take given key from each sub-array and return
* new array with just those corresponding values.
* @param array $list
* @param string $key
* @return array
*/
public static function flattenByKey(array $list, string $key)
{
return array_column($list, $key);
}
/**
* Pass an array of arrays you want to merge. The keys of the outer array will become
* the inner keys of the resulting array, and vice versa.
* @param array $arrays
* @return array
*/
public static function mergeByKey(array $arrays)
{
$empty = array_combine(array_keys($arrays), array_fill(0, count($arrays), false));
$out = [];
foreach ($arrays as $subkey => $array) {
foreach ($array as $key => $item) {
if (!isset($out[$key])) {
$out[$key] = $empty;
}
$out[$key][$subkey] = $item;
}
}
return $out;
}
/**
* Sort array by given column.
* @param array $array
* @param string $column
* @return void
*/
public static function sortByColumn(array &$array, string $column, int $sortFlags = SORT_REGULAR)
{
$sorter = array_column($array, $column);
array_multisort($sorter, $sortFlags, $array);
}
/**
* Check whether $array contains all keys given in $keyList
*
* @param array $array An array
* @param array $keyList A list of strings which must all be valid keys in $array
* @return boolean
*/
public static function hasAllKeys(array $array, array $keyList): bool
{
if (!is_array($array))
return false;
foreach ($keyList as $key) {
if (!isset($array[$key]))
return false;
}
return true;
}
}
|