PHP遍历一个文件夹下所有文件和子文件夹中的所有文件,输出文件名称、清除数组中的空值,并重新排列数组键值

本文主要是介绍PHP遍历一个文件夹下所有文件和子文件夹中的所有文件,输出文件名称、清除数组中的空值,并重新排列数组键值,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/遍历文件夹和子文件夹中所有文件名,输出文件名
<?php
function my_dir($dir) {$files = array();if(@$handle = opendir($dir)) { //注意这里要加一个@,不然会有warning错误提示:)while(($file = readdir($handle)) != = false) {if($file != ".." && $file != ".") { //排除根目录;if(is_dir($dir."/".$file)) { //如果是子文件夹,就进行递归$files[$file] = my_dir($dir."/".$file);} else { //不然就将文件的名字存入数组;$files[] = $file;}}}closedir($handle);return $files;}
}
echo "<pre>";
print_r(my_dir("."));
echo "</pre>";/遍历文件夹和子文件夹中所有文件名,输出所在路径+文件名
<?php	function my_dir($dir) {$filess = array();$files = array();$numsk=0; //计算总数的if(@$handle = opendir($dir)) { //注意这里要加一个@,不然会有warning错误提示:)while(($file = readdir($handle)) !=false) {if($file != ".." && $file != ".") { //排除根目录;if(is_dir($dir."/".$file)) { //如果是子文件夹,就进行递归$files[$file] = my_dir($dir."/".$file); 将路径写入数组中,方便操作文件和保存///                  $num = count($files[$file]); for( $nums= 0;$nums <$num;$nums++){$filess[$numsk] =  $files[$file][$nums]; $numsk = $numsk +1;}} else { //不然就将文件的名字存入数组;$files[] = $dir."/".$file;///将路径写入数组中,方便操作文件和保存/    $numfil = count($files);for($numsa=0;$numsa <$numfil;$numsa++){ $filess[$numsa+$numsk] =   $files[$numsa]; $numsk = $numsk +1;}}}}closedir($handle);return $filess;}
}
echo "<pre>";
//print_r(my_dir("."));
echo "</pre>";$files = my_dir('./TS');
$files = array_filter($files);//删除数组中空的元素var_dump($files);//array_filter()函数的功能是利用回调函数来对数组进行过滤,如果没有回调函数,那么默认就是删除数组中值为false的项目。
例如:
$FileArray=array(0=>'1',1=>'',2=>'',3=>'go');
var_dump(array_file($FileArray))
输出结果为:
array(size=2)0 => string '1' (length=1)3 => string 'go' (length=2)
这样就引申出来一个新问题,如果我想对array_filter()处理过的新数组的键名序列化成0,1,2,3这样的怎么办呢?
这在数组比较中是很有用的,这里有两个函数可以选择array_values(),sort(). array_values()返回数组中所有的值,并给其建立数字索引。(注意,用这个之后key就是数字索引了)sort()对数组进行排序。当函数结束时数组单元将被从最低到最高重新安排。成功返回true (注意: 本函数为 array 中的单元赋予新的键名。这将删除原有的键名而不仅是重新排序。 )*sort函数返回值是布尔类型。这里我选择了array_values()函数来处理:var_dump(array_values(array_filter($FileArray)));
输出结果为:
array(size=2)0 => string '1' (length=1)1=> string 'go' (length=2)

这篇关于PHP遍历一个文件夹下所有文件和子文件夹中的所有文件,输出文件名称、清除数组中的空值,并重新排列数组键值的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/841254

相关文章

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

hdu 1166 敌兵布阵(树状数组 or 线段树)

题意是求一个线段的和,在线段上可以进行加减的修改。 树状数组的模板题。 代码: #include <stdio.h>#include <string.h>const int maxn = 50000 + 1;int c[maxn];int n;int lowbit(int x){return x & -x;}void add(int x, int num){while

顺序表之创建,判满,插入,输出

文章目录 🍊自我介绍🍊创建一个空的顺序表,为结构体在堆区分配空间🍊插入数据🍊输出数据🍊判断顺序表是否满了,满了返回值1,否则返回0🍊main函数 你的点赞评论就是对博主最大的鼓励 当然喜欢的小伙伴可以:点赞+关注+评论+收藏(一键四连)哦~ 🍊自我介绍   Hello,大家好,我是小珑也要变强(也是小珑),我是易编程·终身成长社群的一名“创始团队·嘉宾”

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出

AI(文生语音)-TTS 技术线路探索学习:从拼接式参数化方法到Tacotron端到端输出 在数字化时代,文本到语音(Text-to-Speech, TTS)技术已成为人机交互的关键桥梁,无论是为视障人士提供辅助阅读,还是为智能助手注入声音的灵魂,TTS 技术都扮演着至关重要的角色。从最初的拼接式方法到参数化技术,再到现今的深度学习解决方案,TTS 技术经历了一段长足的进步。这篇文章将带您穿越时

leetcode105 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7   class Solution {public TreeNode buildTree(int[] pr

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,

C 语言基础之数组

文章目录 什么是数组数组变量的声明多维数组 什么是数组 数组,顾名思义,就是一组数。 假如班上有 30 个同学,让你编程统计每个人的分数,求最高分、最低分、平均分等。如果不知道数组,你只能这样写代码: int ZhangSan_score = 95;int LiSi_score = 90;......int LiuDong_score = 100;int Zhou

计算数组的斜率,偏移,R2

模拟Excel中的R2的计算。         public bool fnCheckRear_R2(List<double[]> lRear, int iMinRear, int iMaxRear, ref double dR2)         {             bool bResult = true;             int n = 0;             dou

C# double[] 和Matlab数组MWArray[]转换

C# double[] 转换成MWArray[], 直接赋值就行             MWNumericArray[] ma = new MWNumericArray[4];             double[] dT = new double[] { 0 };             double[] dT1 = new double[] { 0,2 };

PHP原理之内存管理中难懂的几个点

PHP的内存管理, 分为俩大部分, 第一部分是PHP自身的内存管理, 这部分主要的内容就是引用计数, 写时复制, 等等面向应用的层面的管理. 而第二部分就是今天我要介绍的, zend_alloc中描写的关于PHP自身的内存管理, 包括它是如何管理可用内存, 如何分配内存等. 另外, 为什么要写这个呢, 因为之前并没有任何资料来介绍PHP内存管理中使用的策略, 数据结构, 或者算法. 而在我们