网上收集的php的一些代码


//遍历文件夹及子文件夹
//方法一
$arr=system("dir /a /b /s c://svn//*.*");

function my_ls($path){
 foreach (glob($path.DIRECTORY_SEPARATOR.'*') as $f) {
  echo is_dir($f) ? my_ls($f) : $f;
 }
}
//方法二
function get_all_files($path) {
 $list = array();
 foreach( glob( $path .DIRECTORY_SEPARATOR.'*') as $item ) {
  if( is_dir($item ) ) {
   $list = array_merge( $list , get_all_files( $item ) );
  } else {
   $list[] = $item;
  }
 }
 return $list;
}
//方法三
function rFile($p){
$dir_a=array();
$handle=opendir($p);
while ($file = readdir($handle)) {
 if($file!="." && $file!=".."){
  $tmp=$p.DIRECTORY_SEPARATOR.$file;
  if(is_dir($tmp)){
   $dir_a[count($dir_a)]=$tmp;
  }elseif(is_file($tmp)){
   echo $tmp;
  }
 }
}
closedir($handle);
foreach($dir_a as $v){
 rFile($v);
}
}


//获取相对路径
function getRelPath($a,$b){
 $a = explode('/',$a);
 $b = explode('/',$b);

 // $c = array_values(array_diff($a,$b));
 $c = count(array_diff($a,$b))-1;
 $d = array_diff($b,$a);
 return str_repeat("../", $c).implode('/',$d);

}

//二分法查询数组
$n = tuo($array,$searchValue);
echo $n==flase? 'no' : "$n : {$array[$n]}";

function tuo($array,
$searchValue) {
  list($start, $end) = array(0, count($array));
 while($end-$start > 1) {
  $mid = floor(($end-$start)/2);
  if($array[$mid] == $searchValue) return $mid;
  if($array[$mid] < $searchValue)
   list($start, $end) = array($start, $mid);
 else list($start, $end) = array($mid, $end);
  }
  if($array[$mid] == $searchValue) return $mid;
  return flase;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值