removeEmpty(& , = ( => ((::removeEmpty([ = ( ( == ''([ ([] = 1, 'value' => '1-1'), * array('id' => 2, 'value' => '2-1'), * ); * $values = ArrayHelper::getCols($rows, 'value'); * * dump($values); * // 輸出結果為 * // array( * // '1-1', * // '2-1', * // ) * @endcode * * @param array $arr 資料來源 * @param string $col 要查詢的鍵 * * @return array 包含指定鍵所有值的數組 getCols(, = ( (([[] = [ 1, 'value' => '1-1'), * array('id' => 2, 'value' => '2-1'), * ); * $hashmap = ArrayHelper::toHashmap($rows, 'id', 'value'); * * dump($hashmap); * // 輸出結果為 * // array( * // 1 => '1-1', * // 2 => '2-1', * // ) * @endcode * * 如果省略 $valueField 參數,則轉換結果每一項為包含該項所有資料的數組。 * * 用法2: * @code php * $rows = array( * array('id' => 1, 'value' => '1-1'), * array('id' => 2, 'value' => '2-1'), * ); * $hashmap = ArrayHelper::toHashmap($rows, 'id'); * * dump($hashmap); * // 輸出結果為 * // array( * // 1 => array('id' => 1, 'value' => '1-1'), * // 2 => array('id' => 2, 'value' => '2-1'), * // ) * @endcode * * @param array $arr 資料來源 * @param string $keyField 按照什麼鍵的值進行轉換 * @param string $valueField 對應的索引值 * * @return array 轉換後的 HashMap 樣式數組 toHashmap(, , = = ( ( [[]] = [ ( [[]] = 1, 'value' => '1-1', 'parent' => 1), * array('id' => 2, 'value' => '2-1', 'parent' => 1), * array('id' => 3, 'value' => '3-1', 'parent' => 1), * array('id' => 4, 'value' => '4-1', 'parent' => 2), * array('id' => 5, 'value' => '5-1', 'parent' => 2), * array('id' => 6, 'value' => '6-1', 'parent' => 3), * ); * $values = ArrayHelper::groupBy($rows, 'parent'); * * dump($values); * // 按照 parent 分組的輸出結果為 * // array( * // 1 => array( * // array('id' => 1, 'value' => '1-1', 'parent' => 1), * // array('id' => 2, 'value' => '2-1', 'parent' => 1), * // array('id' => 3, 'value' => '3-1', 'parent' => 1), * // ), * // 2 => array( * // array('id' => 4, 'value' => '4-1', 'parent' => 2), * // array('id' => 5, 'value' => '5-1', 'parent' => 2), * // ), * // 3 => array( * // array('id' => 6, 'value' => '6-1', 'parent' => 3), * // ), * // ) * @endcode * * @param array $arr 資料來源 * @param string $keyField 作為分組依據的鍵名 * * @return array 分組後的結果 groupBy(, = ( = [[][] = 1, 'value' => '1-1', 'parent' => 0), * array('id' => 2, 'value' => '2-1', 'parent' => 0), * array('id' => 3, 'value' => '3-1', 'parent' => 0), * * array('id' => 7, 'value' => '2-1-1', 'parent' => 2), * array('id' => 8, 'value' => '2-1-2', 'parent' => 2), * array('id' => 9, 'value' => '3-1-1', 'parent' => 3), * array('id' => 10, 'value' => '3-1-1-1', 'parent' => 9), * ); * * $tree = ArrayHelper::tree($rows, 'id', 'parent', 'nodes'); * * dump($tree); * // 輸出結果為: * // array( * // array('id' => 1, ..., 'nodes' => array()), * // array('id' => 2, ..., 'nodes' => array( * // array(..., 'parent' => 2, 'nodes' => array()), * // array(..., 'parent' => 2, 'nodes' => array()), * // ), * // array('id' => 3, ..., 'nodes' => array( * // array('id' => 9, ..., 'parent' => 3, 'nodes' => array( * // array(..., , 'parent' => 9, 'nodes' => array(), * // ), * // ), * // ) * @endcode * * 如果要獲得任意節點為根的子樹,可以使用 $refs 參數: * @code php * $refs = null; * $tree = ArrayHelper::tree($rows, 'id', 'parent', 'nodes', $refs); * * // 輸出 id 為 3 的節點及其所有子節點 * $id = 3; * dump($refs[$id]); * @endcode * * @param array $arr 資料來源 * @param string $keyNodeId 節點ID欄位名 * @param string $keyParentId 節點父ID欄位名 * @param string $keyChildrens 儲存子節點的欄位名 * @param boolean $refs 是否在返回結果中包含節點引用 * * return array 樹形結構的數組 toTree(, , = 'parent_id', = 'childrens', & = = ( => [][] = [[]] =& [ = ( => = [ ( (!([[] =& [ =& [[][] =& [[] =& [ treeToArray(, = 'childrens' = (([]) && ([ ([] = (, self::treeToArray(, ([[] = [] = 1, 'value' => '1-1', 'parent' => 1), * array('id' => 2, 'value' => '2-1', 'parent' => 1), * array('id' => 3, 'value' => '3-1', 'parent' => 1), * array('id' => 4, 'value' => '4-1', 'parent' => 2), * array('id' => 5, 'value' => '5-1', 'parent' => 2), * array('id' => 6, 'value' => '6-1', 'parent' => 3), * ); * * $rows = ArrayHelper::sortByCol($rows, 'id', SORT_DESC); * dump($rows); * // 輸出結果為: * // array( * // array('id' => 6, 'value' => '6-1', 'parent' => 3), * // array('id' => 5, 'value' => '5-1', 'parent' => 2), * // array('id' => 4, 'value' => '4-1', 'parent' => 2), * // array('id' => 3, 'value' => '3-1', 'parent' => 1), * // array('id' => 2, 'value' => '2-1', 'parent' => 1), * // array('id' => 1, 'value' => '1-1', 'parent' => 1), * // ) * @endcode * * @param array $array 要排序的數組 * @param string $keyname 排序的鍵 * @param int $dir 排序方向 * * @return array 排序後的數組 sortByCol(, , = self::sortByMultiCols(, ( => SORT_ASC, * 'name' => SORT_DESC, * )); * @endcode * * @param array $rowset 要排序的數組 * @param array $args 排序的鍵 * * @return array 排序後的數組 sortByMultiCols(, = = '' ( => ( => [][] = [ .= '$sortArray[\'' . . '\'], ' . . ', ' (() || ( ('array_multisort(' . . '$rowset);'
http://www.bkjia.com/PHPjc/440429.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/440429.htmlTechArticleremoveEmpty( , = ( = ( ( ::removeEmpty( [ = ( ( == '' ( [ ( [ ] = getCols( , = ( ( ( [ [] = [ toHashmap( , , = = ( ( [ [ ]] = [ ( [ [ ]] = groupBy( , = ( = [ [ ][] = toTree( , , =...