递归获取二维数组后代、删除后代

 
  

递归获取二维数组后代、删除后代

/**
 * 获取后代
 * @param array $arr 需要操作的二维数组
 * @param int $id 需要获取的编号
 * @param string $idkey 唯一编号字段
 * @param string $pidkey 父编号字段
 * @param int $self 是否包含自身
 * @return array
 */
 
 
function getChilds($arr,$id,$idkey,$pidkey,$self = 0){
    $c = array();
    foreach ($arr as $k => $value){
        if($self && $value[$idkey] == $id){
            $c[] = $value;
            $self = 0;
        }
        if($value[$pidkey] == $id){
            $c[] = $value;
            $c = array_merge($c,getChilds($arr,$value[$idkey],$idkey,$pidkey,0));
        }
 
    }
    return $c;
}
 
/**
 * 移除后代
 * @param array $arr 需要操作的二维数组
 * @param int $id 需要移除的编号
 * @param string $idkey 唯一编号字段
 * @param string $pidkey 父编号字段
 * @param int $self 是否移除自身
 * @param int $array_values 是否重新索引数组
 * @return array
 */
function removeChilds($arr,$id,$idkey,$pidkey,$self = 0,$array_values = 0){
    $c = getChilds($arr, $id, $idkey, $pidkey,$self);
    foreach ($c as $o){
        foreach ($arr as $k => $v){
            if($o[$idkey] == $v[$idkey]){
                unset($arr[$k]);
                break;
            }
        }
    }
    return = $array_values ? array_values($arr) : $arr;
}

 

转载于:https://www.cnblogs.com/qhorse/p/4837246.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值