好的,所以我对如何调整代码有些迷惑。到目前为止,我的代码可以读取目录中的任何Json文件,将其解析并放入表中-效果很好,因为我每表行仅使用1个JSON文件。
我现在需要做的是,每个IP地址现在给我3个JSON文件,这些文件放在以IP地址作为名称的文件夹中。在我的主目录中,我将有很多文件夹,每个文件夹中都有3个JSON文件。
我想读取每个文件夹中的每个文件,将解析的信息放在表中,然后作为新行移至下一个文件夹,并执行相同的操作。
FOR REFERENCE::
Current file layout:
FOLDER-->JSON
-->JSON
-->JSON
New file layout:
FOLDER-->IPADDRESS-->JSONFILE1
-->JSONFILE2
-->JSONFILE3
-->IPADDRESS2-->JSONFILE1
--JSONFILE2
-->JSONFILE3
用于读取目录中任何JSON文件的当前代码:
$dir = "my dir";
if (is_dir($dir)) {
if ($dh = opendir($dir)) {
foreach(glob("*_name.json") as $filename) {
$data = file_get_contents($filename);
$testing = json_decode($data, true);
echo "<tr>";
echo "<td>{$filename }</td>";
foreach($testing[0] as $row) {
// code for parsing here ...
}
}
}
}
答案 0 :(得分:0)
在这里使用RecursiveIteratorIterator类
function Get_Files()
{
$dir = "my_dir";
$init = new RecursiveIteratorIterator(new RecursiveDirectoryIterator($dir));
$files = array();
foreach ($init as $file) {
if ($file->isDir()) {
continue;
}
$files[] = $file->getPathname();
}
return $files;
}
foreach (Get_Files() as $file) {
$data = file_get_contents($file);
$testing = json_decode($data, true);
echo "<tr>";
echo "<td>{$file}</td></tr>";
}
输出:
my_dir\192.168.0.1\JSONFILE1.json
my_dir\192.168.0.1\JSONFILE2.json