博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHP数组操作函数
阅读量:5782 次
发布时间:2019-06-18

本文共 3610 字,大约阅读时间需要 12 分钟。

$value) { if (is_array($value)) { array_remove_empty($arr[$key]); } else { $value = trim($value); if ($value == '') { unset($arr[$key]); } elseif ($trim) { $arr[$key] = $value; } } }} * 从一个二维数组中返回指定键的所有值 * * @param array $arr * @param string $col * * @return arrayfunction array_col_values(& $arr, $col){ $ret = array(); foreach ($arr as $row) { if (isset($row[$col])) { $ret[] = $row[$col]; } } return $ret;} * 将一个二维数组转换为 hashmap * * 如果省略 $valueField 参数,则转换结果每一项为包含该项所有数据的数组。 * * @param array $arr * @param string $keyField * @param string $valueField * * @return arrayfunction array_to_hashmap(& $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;} * 将一个二维数组按照指定字段的值分组 * * @param array $arr * @param string $keyField * * @return arrayfunction array_group_by(& $arr, $keyField){ $ret = array(); foreach ($arr as $row) { $key = $row[$keyField]; $ret[$key][] = $row; } return $ret;} * 将一个平面的二维数组按照指定的字段转换为树状结构 * * 当 $returnReferences 参数为 true 时,返回结果的 tree 字段为树,refs 字段则为节点引用。 * 利用返回的节点引用,可以很方便的获取包含以任意节点为根的子树。 * * @param array $arr 原始数据 * @param string $fid 节点ID字段名 * @param string $fparent 节点父ID字段名 * @param string $fchildrens 保存子节点的字段名 * @param boolean $returnReferences 是否在返回结果中包含节点引用 * * return arrayfunction array_to_tree($arr, $fid, $fparent = 'parent_id', $fchildrens = 'childrens', $returnReferences = false){ $pkvRefs = array(); foreach ($arr as $offset => $row) { $pkvRefs[$row[$fid]] =& $arr[$offset]; } $tree = array(); foreach ($arr as $offset => $row) { $parentId = $row[$fparent]; if ($parentId) { if (!isset($pkvRefs[$parentId])) { continue; } $parent =& $pkvRefs[$parentId]; $parent[$fchildrens][] =& $arr[$offset]; } else { $tree[] =& $arr[$offset]; } } if ($returnReferences) { return array('tree' => $tree, 'refs' => $pkvRefs); } else { return $tree; }} * 将树转换为平面的数组 * * @param array $node * @param string $fchildrens * * @return arrayfunction tree_to_array(& $node, $fchildrens = 'childrens'){ $ret = array(); if (isset($node[$fchildrens]) && is_array($node[$fchildrens])) { foreach ($node[$fchildrens] as $child) { $ret = array_merge($ret, tree_to_array($child, $fchildrens)); } unset($node[$fchildrens]); $ret[] = $node; } else { $ret[] = $node; } return $ret;} * 根据指定的键值对数组排序 * * @param array $array 要排序的数组 * @param string $keyname 键值名称 * @param int $sortDirection 排序方向 * * @return arrayfunction array_column_sort($array, $keyname, $sortDirection = SORT_ASC){ return array_sortby_multifields($array, array($keyname => $sortDirection));} * 将一个二维数组按照指定列进行排序,类似 SQL 语句中的 ORDER BY * * @param array $rowset * @param array $argsfunction array_sortby_multifields($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_r('array_multisort(' . $sortRule . '$rowset);'); return $rowset;}?>

 

转载地址:http://fdcyx.baihongyu.com/

你可能感兴趣的文章
2048游戏C语言代码
查看>>
ZOJ Monthly, October 2010 ABEFI
查看>>
小议常被忽略的a标签:visited属性的特殊用法
查看>>
生成二维码Base64图片
查看>>
SQL Server 权限管理
查看>>
有趣的换零钱问题
查看>>
Rabbit Mq 异步消息的使用(转载)
查看>>
初始Agile Software Development
查看>>
RCP:如何移除Toolbar中的Quick Access
查看>>
CSS模块化
查看>>
报错:System.Data.Entity.Infrastructure.DbUpdateException 更新条目时出错
查看>>
[APM] 解读2016之APM国内篇:快速增长的APM市场和技术
查看>>
【学习Android NDK开发】Java通过JNI调用native方法
查看>>
文本数据的机器学习自动分类方法(转)
查看>>
SGU148 B-Station(堆)
查看>>
DotNetBar 6.6.0.1 Crack
查看>>
正确地做事与做正确的事同样重要
查看>>
ASP.NET MVC是否会成为ASP.NET未来主流的UI平台?
查看>>
[转] 企业版IDP的申请及“In House”发布
查看>>
hadoop实战之动态添加节点
查看>>