PHP實現(xiàn)的操作數(shù)組類庫定義與用法示例
本文實例講述了PHP實現(xiàn)的操作數(shù)組類庫定義與用法。分享給大家供大家參考,具體如下:
類庫(完整類庫):
<?php
class ArrayHelper{
/**
* 從數(shù)組中刪除空白的元素(包括只有空白字符的元素)
*
* 用法:
* @code php
* $arr = array('', 'test', ' ');
* ArrayHelper::removeEmpty($arr);
*
* dump($arr);
* // 輸出結(jié)果中將只有 'test'
* @endcode
*
* @param array $arr 要處理的數(shù)組
* @param boolean $trim 是否對數(shù)組元素調(diào)用 trim 函數(shù)
*/
static function removeEmpty(& $arr, $trim = TRUE)
{
foreach ($arr as $key => $value)
{
if (is_array($value))
{
self::removeEmpty($arr[$key]);
}
else
{
$value = trim($value);
if ($value == '')
{
unset($arr[$key]);
}
elseif ($trim)
{
$arr[$key] = $value;
}
}
}
}
/**
* 從一個二維數(shù)組中返回指定鍵的所有值
*
* 用法:
* @code php
* $rows = array(
* array('id' => 1, 'value' => '1-1'),
* array('id' => 2, 'value' => '2-1'),
* );
* $values = ArrayHelper::getCols($rows, 'value');
*
* dump($values);
* // 輸出結(jié)果為
* // array(
* // '1-1',
* // '2-1',
* // )
* @endcode
*
* @param array $arr 數(shù)據(jù)源
* @param string $col 要查詢的鍵
*
* @return array 包含指定鍵所有值的數(shù)組
*/
static function getCols($arr, $col)
{
$ret = array();
foreach ($arr as $row)
{
if (isset($row[$col])) {
$ret[] = $row[$col];
}
}
return $ret;
}
/**
* 將一個二維數(shù)組轉(zhuǎn)換為 HashMap,并返回結(jié)果
*
* 用法1:
* @code php
* $rows = array(
* array('id' => 1, 'value' => '1-1'),
* array('id' => 2, 'value' => '2-1'),
* );
* $hashmap = ArrayHelper::toHashmap($rows, 'id', 'value');
*
* dump($hashmap);
* // 輸出結(jié)果為
* // array(
* // 1 => '1-1',
* // 2 => '2-1',
* // )
* @endcode
*
* 如果省略 $valueField 參數(shù),則轉(zhuǎn)換結(jié)果每一項為包含該項所有數(shù)據(jù)的數(shù)組。
*
* 用法2:
* @code php
* $rows = array(
* array('id' => 1, 'value' => '1-1'),
* array('id' => 2, 'value' => '2-1'),
* );
* $hashmap = ArrayHelper::toHashmap($rows, 'id');
*
* dump($hashmap);
* // 輸出結(jié)果為
* // array(
* // 1 => array('id' => 1, 'value' => '1-1'),
* // 2 => array('id' => 2, 'value' => '2-1'),
* // )
* @endcode
*
* @param array $arr 數(shù)據(jù)源
* @param string $keyField 按照什么鍵的值進行轉(zhuǎn)換
* @param string $valueField 對應(yīng)的鍵值
*
* @return array 轉(zhuǎn)換后的 HashMap 樣式數(shù)組
*/
static function toHashmap($arr, $keyField, $valueField = NULL)
{
$ret = array();
if ($valueField)
{
foreach ($arr as $row)
{
$ret[$row[$keyField]] = $row[$valueField];
}
}
else
{
foreach ($arr as $row)
{
$ret[$row[$keyField]] = $row;
}
}
return $ret;
}
/**
* 將一個二維數(shù)組按照指定字段的值分組
*
* 用法:
* @endcode
*
* @param array $arr 數(shù)據(jù)源
* @param string $keyField 作為分組依據(jù)的鍵名
*
* @return array 分組后的結(jié)果
*/
static function groupBy($arr, $keyField)
{
$ret = array();
foreach ($arr as $row)
{
$key = $row[$keyField];
$ret[$key][] = $row;
}
return $ret;
}
/**
* 將一個平面的二維數(shù)組按照指定的字段轉(zhuǎn)換為樹狀結(jié)構(gòu)
*
*
* 如果要獲得任意節(jié)點為根的子樹,可以使用 $refs 參數(shù):
* @code php
* $refs = null;
* $tree = ArrayHelper::tree($rows, 'id', 'parent', 'nodes', $refs);
*
* // 輸出 id 為 3 的節(jié)點及其所有子節(jié)點
* $id = 3;
* dump($refs[$id]);
* @endcode
*
* @param array $arr 數(shù)據(jù)源
* @param string $keyNodeId 節(jié)點ID字段名
* @param string $keyParentId 節(jié)點父ID字段名
* @param string $keyChildrens 保存子節(jié)點的字段名
* @param boolean $refs 是否在返回結(jié)果中包含節(jié)點引用
*
* return array 樹形結(jié)構(gòu)的數(shù)組
*/
static function toTree($arr, $keyNodeId, $keyParentId = 'parent_id', $keyChildrens = 'childrens', & $refs = NULL)
{
$refs = array();
foreach ($arr as $offset => $row)
{
$arr[$offset][$keyChildrens] = array();
$refs[$row[$keyNodeId]] =& $arr[$offset];
}
$tree = array();
foreach ($arr as $offset => $row)
{
$parentId = $row[$keyParentId];
if ($parentId)
{
if (!isset($refs[$parentId]))
{
$tree[] =& $arr[$offset];
continue;
}
$parent =& $refs[$parentId];
$parent[$keyChildrens][] =& $arr[$offset];
}
else
{
$tree[] =& $arr[$offset];
}
}
return $tree;
}
/**
* 將樹形數(shù)組展開為平面的數(shù)組
*
* 這個方法是 tree() 方法的逆向操作。
*
* @param array $tree 樹形數(shù)組
* @param string $keyChildrens 包含子節(jié)點的鍵名
*
* @return array 展開后的數(shù)組
*/
static function treeToArray($tree, $keyChildrens = 'childrens')
{
$ret = array();
if (isset($tree[$keyChildrens]) && is_array($tree[$keyChildrens]))
{
foreach ($tree[$keyChildrens] as $child)
{
$ret = array_merge($ret, self::treeToArray($child, $keyChildrens));
}
unset($node[$keyChildrens]);
$ret[] = $tree;
}
else
{
$ret[] = $tree;
}
return $ret;
}
/**
* 根據(jù)指定的鍵對數(shù)組排序
*
* @endcode
*
* @param array $array 要排序的數(shù)組
* @param string $keyname 排序的鍵
* @param int $dir 排序方向
*
* @return array 排序后的數(shù)組
*/
static function sortByCol($array, $keyname, $dir = SORT_ASC)
{
return self::sortByMultiCols($array, array($keyname => $dir));
}
/**
* 將一個二維數(shù)組按照多個列進行排序,類似 SQL 語句中的 ORDER BY
*
* 用法:
* @code php
* $rows = ArrayHelper::sortByMultiCols($rows, array(
* 'parent' => SORT_ASC,
* 'name' => SORT_DESC,
* ));
* @endcode
*
* @param array $rowset 要排序的數(shù)組
* @param array $args 排序的鍵
*
* @return array 排序后的數(shù)組
*/
static function sortByMultiCols($rowset, $args)
{
$sortArray = array();
$sortRule = '';
foreach ($args as $sortField => $sortDir)
{
foreach ($rowset as $offset => $row)
{
$sortArray[$sortField][$offset] = $row[$sortField];
}
$sortRule .= '$sortArray[\'\' . $sortField .\'\'], ' . $sortDir . ', ';
}
if (empty($sortArray) || empty($sortRule)) {
return $rowset;
}
eval('array_multisort(' . $sortRule . '$rowset);');
return $rowset;
}
}
?>
用法示例:
從數(shù)組中刪除空白的元素(包括只有空白字符的元素)
用法:
$arr = array('', 'test', ' ');
ArrayHelper::removeEmpty($arr);
var_dump($arr);
輸出結(jié)果中將只有 'test'
array(1) {
[1]=>
string(4) "test"
}
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)組(Array)操作技巧大全》、《php排序算法總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計算法總結(jié)》、《php字符串(string)用法總結(jié)》及《PHP常用遍歷算法與技巧總結(jié)》
希望本文所述對大家PHP程序設(shè)計有所幫助。
相關(guān)文章
基于命令行執(zhí)行帶參數(shù)的php腳本并取得參數(shù)的方法
這篇文章主要介紹了基于命令行執(zhí)行帶參數(shù)的php腳本并取得參數(shù)的方法,分析了命令行運行PHP代碼的原理、用法與相關(guān)注意事項,需要的朋友可以參考下2016-01-01
兩級聯(lián)動select刷新后其值保持不變的實現(xiàn)方法
兩級聯(lián)動select刷新后,select值保持不變即點擊提交按鈕后,頁面select中繼續(xù)維持提交前的值,下面有個不錯的示例,大家可以參考下2014-01-01
PHP+AJAX實現(xiàn)無刷新注冊(帶用戶名實時檢測)
PHP+AJAX實現(xiàn)無刷新注冊(帶用戶名實時檢測)...2007-01-01
PHP獲取訪問頁面HTTP狀態(tài)碼的實現(xiàn)代碼
這篇文章主要介紹了一個PHP獲取訪問頁面HTTP狀態(tài)的再封裝函數(shù),需要的朋友可以參考下2016-11-11

