国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開發(fā) > PHP > 正文

PHP數(shù)組操作類實(shí)例

2024-05-04 23:37:42
字體:
供稿:網(wǎng)友

這篇文章主要介紹了PHP數(shù)組操作類,涉及php針對(duì)數(shù)組的刪除、轉(zhuǎn)換、分組、排序等相關(guān)操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下

本文實(shí)例講述了PHP數(shù)組操作類。分享給大家供大家參考。具體如下:

 

 
  1. class ArrayHelper{ 
  2. /** 
  3. * 從數(shù)組中刪除空白的元素(包括只有空白字符的元素) 
  4. * 
  5. * 用法: 
  6. * @code php 
  7. * $arr = array('', 'test', ' '); 
  8. * ArrayHelper::removeEmpty($arr); 
  9. * 
  10. * dump($arr); 
  11. * // 輸出結(jié)果中將只有 'test' 
  12. * @endcode 
  13. * 
  14. * @param array $arr 要處理的數(shù)組 
  15. * @param boolean $trim 是否對(duì)數(shù)組元素調(diào)用 trim 函數(shù) 
  16. */ 
  17. static function removeEmpty(& $arr, $trim = TRUE) 
  18. foreach ($arr as $key => $value) 
  19. if (is_array($value)) 
  20. self::removeEmpty($arr[$key]); 
  21. else 
  22. $value = trim($value); 
  23. if ($value == ''
  24. unset($arr[$key]); 
  25. elseif ($trim) 
  26. $arr[$key] = $value; 
  27. /** 
  28. * 從一個(gè)二維數(shù)組中返回指定鍵的所有值 
  29. * 
  30. * 用法: 
  31. * @code php 
  32. * $rows = array( 
  33. * array('id' => 1, 'value' => '1-1'), 
  34. * array('id' => 2, 'value' => '2-1'), 
  35. * ); 
  36. * $values = ArrayHelper::getCols($rows, 'value'); 
  37. * 
  38. * dump($values); 
  39. * // 輸出結(jié)果為 
  40. * // array( 
  41. * // '1-1', 
  42. * // '2-1', 
  43. * // ) 
  44. * @endcode 
  45. * 
  46. * @param array $arr 數(shù)據(jù)源 
  47. * @param string $col 要查詢的鍵 
  48. * 
  49. * @return array 包含指定鍵所有值的數(shù)組 
  50. */ 
  51. static function getCols($arr, $col) 
  52. $ret = array(); 
  53. foreach ($arr as $row) 
  54. if (isset($row[$col])) { 
  55. $ret[] = $row[$col]; 
  56. return $ret; 
  57. /** 
  58. * 將一個(gè)二維數(shù)組轉(zhuǎn)換為 HashMap,并返回結(jié)果 
  59. * 
  60. * 用法1: 
  61. * @code php 
  62. * $rows = array( 
  63. * array('id' => 1, 'value' => '1-1'), 
  64. * array('id' => 2, 'value' => '2-1'), 
  65. * ); 
  66. * $hashmap = ArrayHelper::toHashmap($rows, 'id', 'value'); 
  67. * 
  68. * dump($hashmap); 
  69. * // 輸出結(jié)果為 
  70. * // array( 
  71. * // 1 => '1-1', 
  72. * // 2 => '2-1', 
  73. * // ) 
  74. * @endcode 
  75. * 
  76. * 如果省略 $valueField 參數(shù),則轉(zhuǎn)換結(jié)果每一項(xiàng)為包含該項(xiàng)所有數(shù)據(jù)的數(shù)組。 
  77. * 
  78. * 用法2: 
  79. * @code php 
  80. * $rows = array( 
  81. * array('id' => 1, 'value' => '1-1'), 
  82. * array('id' => 2, 'value' => '2-1'), 
  83. * ); 
  84. * $hashmap = ArrayHelper::toHashmap($rows, 'id'); 
  85. * 
  86. * dump($hashmap); 
  87. * // 輸出結(jié)果為 
  88. * // array( 
  89. * // 1 => array('id' => 1, 'value' => '1-1'), 
  90. * // 2 => array('id' => 2, 'value' => '2-1'), 
  91. * // ) 
  92. * @endcode 
  93. * 
  94. * @param array $arr 數(shù)據(jù)源 
  95. * @param string $keyField 按照什么鍵的值進(jìn)行轉(zhuǎn)換 
  96. * @param string $valueField 對(duì)應(yīng)的鍵值 
  97. * 
  98. * @return array 轉(zhuǎn)換后的 HashMap 樣式數(shù)組 
  99. */ 
  100. static function toHashmap($arr, $keyField, $valueField = NULL) 
  101. $ret = array(); 
  102. if ($valueField) 
  103. foreach ($arr as $row) 
  104. $ret[$row[$keyField]] = $row[$valueField]; 
  105. else 
  106. foreach ($arr as $row) 
  107. $ret[$row[$keyField]] = $row; 
  108. return $ret; 
  109. /** 
  110. * 將一個(gè)二維數(shù)組按照指定字段的值分組 
  111. * 
  112. * 用法: 
  113. * @endcode 
  114. * 
  115. * @param array $arr 數(shù)據(jù)源 
  116. * @param string $keyField 作為分組依據(jù)的鍵名 
  117. * 
  118. * @return array 分組后的結(jié)果 
  119. */ 
  120. static function groupBy($arr, $keyField) 
  121. $ret = array(); 
  122. foreach ($arr as $row) 
  123. $key = $row[$keyField]; 
  124. $ret[$key][] = $row; 
  125. return $ret; 
  126. /** 
  127. * 將一個(gè)平面的二維數(shù)組按照指定的字段轉(zhuǎn)換為樹狀結(jié)構(gòu) 
  128. * 
  129. * 
  130. * 如果要獲得任意節(jié)點(diǎn)為根的子樹,可以使用 $refs 參數(shù): 
  131. * @code php 
  132. * $refs = null; 
  133. * $tree = ArrayHelper::tree($rows, 'id', 'parent', 'nodes', $refs); 
  134. * 
  135. * // 輸出 id 為 3 的節(jié)點(diǎn)及其所有子節(jié)點(diǎn) 
  136. * $id = 3; 
  137. * dump($refs[$id]); 
  138. * @endcode 
  139. * 
  140. * @param array $arr 數(shù)據(jù)源 
  141. * @param string $keyNodeId 節(jié)點(diǎn)ID字段名 
  142. * @param string $keyParentId 節(jié)點(diǎn)父ID字段名 
  143. * @param string $keyChildrens 保存子節(jié)點(diǎn)的字段名 
  144. * @param boolean $refs 是否在返回結(jié)果中包含節(jié)點(diǎn)引用 
  145. * 
  146. * return array 樹形結(jié)構(gòu)的數(shù)組 
  147. */ 
  148. static function toTree($arr, $keyNodeId, $keyParentId = 'parent_id', $keyChildrens = 'childrens', & $refs = NULL) 
  149. $refs = array(); 
  150. foreach ($arr as $offset => $row) 
  151. $arr[$offset][$keyChildrens] = array(); 
  152. $refs[$row[$keyNodeId]] =& $arr[$offset]; 
  153. $tree = array(); 
  154. foreach ($arr as $offset => $row) 
  155. $parentId = $row[$keyParentId]; 
  156. if ($parentId) 
  157. if (!isset($refs[$parentId])) 
  158. $tree[] =& $arr[$offset]; 
  159. continue
  160. $parent =& $refs[$parentId]; 
  161. $parent[$keyChildrens][] =& $arr[$offset]; 
  162. else 
  163. $tree[] =& $arr[$offset]; 
  164. return $tree; 
  165. /** 
  166. * 將樹形數(shù)組展開為平面的數(shù)組 
  167. * 
  168. * 這個(gè)方法是 tree() 方法的逆向操作。 
  169. * 
  170. * @param array $tree 樹形數(shù)組 
  171. * @param string $keyChildrens 包含子節(jié)點(diǎn)的鍵名 
  172. * 
  173. * @return array 展開后的數(shù)組 
  174. */ 
  175. static function treeToArray($tree, $keyChildrens = 'childrens'
  176. $ret = array(); 
  177. if (isset($tree[$keyChildrens]) && is_array($tree[$keyChildrens])) 
  178. foreach ($tree[$keyChildrens] as $child) 
  179. $ret = array_merge($ret, self::treeToArray($child, $keyChildrens)); 
  180. unset($node[$keyChildrens]); 
  181. $ret[] = $tree; 
  182. else 
  183. $ret[] = $tree; 
  184. return $ret; 
  185. /** 
  186. * 根據(jù)指定的鍵對(duì)數(shù)組排序 
  187. * 
  188. * @endcode 
  189. * 
  190. * @param array $array 要排序的數(shù)組 
  191. * @param string $keyname 排序的鍵 
  192. * @param int $dir 排序方向 
  193. * 
  194. * @return array 排序后的數(shù)組 
  195. */ 
  196. static function sortByCol($array, $keyname, $dir = SORT_ASC) 
  197. return self::sortByMultiCols($array, array($keyname => $dir)); 
  198. /** 
  199. * 將一個(gè)二維數(shù)組按照多個(gè)列進(jìn)行排序,類似 SQL 語句中的 ORDER BY 
  200. * 
  201. * 用法: 
  202. * @code php 
  203. * $rows = ArrayHelper::sortByMultiCols($rows, array( 
  204. * 'parent' => SORT_ASC, 
  205. * 'name' => SORT_DESC, 
  206. * )); 
  207. * @endcode 
  208. * 
  209. * @param array $rowset 要排序的數(shù)組 
  210. * @param array $args 排序的鍵 
  211. * 
  212. * @return array 排序后的數(shù)組 
  213. */ 
  214. static function sortByMultiCols($rowset, $args) 
  215. $sortArray = array(); 
  216. $sortRule = ''
  217. foreach ($args as $sortField => $sortDir) 
  218. foreach ($rowset as $offset => $row) 
  219. $sortArray[$sortField][$offset] = $row[$sortField]; 
  220. $sortRule .= '$sortArray[/'' . $sortField . '/'], ' . $sortDir . ', '
  221. if (empty($sortArray) || empty($sortRule)) { 
  222. return $rowset; 
  223. eval('array_multisort(' . $sortRule . '$rowset);'); 
  224. return $rowset; 

希望本文所述對(duì)大家的php程序設(shè)計(jì)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 新巴尔虎左旗| 射洪县| 凭祥市| 汉源县| 滨海县| 新巴尔虎左旗| 德惠市| 香格里拉县| 津市市| 珲春市| 平舆县| 雅江县| 开封市| 景泰县| 玉溪市| 岳普湖县| 抚远县| 海原县| 临猗县| 望江县| 扎鲁特旗| 哈巴河县| 柏乡县| 惠州市| 临潭县| 武川县| 鹤山市| 绍兴县| 嘉祥县| 光泽县| 濉溪县| 鸡西市| 庆安县| 浦县| 武邑县| 扎囊县| 绩溪县| 翁牛特旗| 百色市| 乌兰察布市| 昭通市|