數組操作類_PHP教程

來源:互聯網
上載者:User
      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( , , =...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.