PHP MySQL - 需要显示文件列表及其文件大小,格式化。 Redeclare功能错误

时间:2014-07-10 15:44:44

标签: php mysql function filesize redeclare

我坚持认为对于经验丰富的PHP人来说可能很简单。我得到了一个"无法重新声明功能"当我尝试格式化我查询mysql数据库的文件列表的文件大小时出错。

据我所知,我不应该把这个函数放在while语句中,但是如果我不这样做,那么$ bytes变量对于每个文件都不会改变。从数据库中调用。有人可以解释我是如何做到这一点的吗?

以下是代码:

while ($docRows = mysql_fetch_array($docsQuery)) {

 $docID = $docRows['ID'];
 $docName = htmlspecialchars($docRows['docName']);
 $docDescription = htmlspecialchars($docRows['LEFT(docDescription, 50)']);
 $docPath = $docRows['filePath'];
 $origName = $docRows['origName'];
 $bytes = filesize($_SERVER['DOCUMENT_ROOT']."/documents/".$origName."");

 function bytesToSize($bytes, $precision = 2) {  
$kilobyte = 1024;
$megabyte = $kilobyte * 1024;
$gigabyte = $megabyte * 1024;
$terabyte = $gigabyte * 1024;

if (($bytes >= 0) && ($bytes < $kilobyte)) {
    return $bytes . ' B';

} elseif (($bytes >= $kilobyte) && ($bytes < $megabyte)) {
    return round($bytes / $kilobyte, $precision) . ' KB';

} elseif (($bytes >= $megabyte) && ($bytes < $gigabyte)) {
    return round($bytes / $megabyte, $precision) . ' MB';

} elseif (($bytes >= $gigabyte) && ($bytes < $terabyte)) {
    return round($bytes / $gigabyte, $precision) . ' GB';

} elseif ($bytes >= $terabyte) {
    return round($bytes / $terabyte, $precision) . ' TB';
} else {
    return $bytes . ' B';
}
}

echo ('<tr>
    <td><a href="'.$docPath.'">'.$docName.'</a> ('.bytesToSize($bytes).')</td>
    <td>');

    if (!empty($docDescription)) {
    echo(''.$docDescription.'...');
    }
 else {
    // don't show description if there isn't one
    }

echo ('</td>
</tr>
');

} // end while

2 个答案:

答案 0 :(得分:0)

你必须在循环之外声明你的函数,然后就像你正在使用它一样。

答案 1 :(得分:0)

你需要定义你的函数然后调用它,如果你多次定义一个函数PHP会抛出一个错误,这就是为什么你不应该在循环中定义你的函数。

关于echo它不需要括号,请看下面的代码:

function bytesToSize($bytes, $precision = 2) {  
    $kilobyte = 1024;
    $megabyte = $kilobyte * 1024;
    $gigabyte = $megabyte * 1024;
    $terabyte = $gigabyte * 1024;

    if (($bytes >= 0) && ($bytes < $kilobyte)) {
        return $bytes . ' B';

    } elseif (($bytes >= $kilobyte) && ($bytes < $megabyte)) {
        return round($bytes / $kilobyte, $precision) . ' KB';

    } elseif (($bytes >= $megabyte) && ($bytes < $gigabyte)) {
        return round($bytes / $megabyte, $precision) . ' MB';

    } elseif (($bytes >= $gigabyte) && ($bytes < $terabyte)) {
        return round($bytes / $gigabyte, $precision) . ' GB';

    } elseif ($bytes >= $terabyte) {
        return round($bytes / $terabyte, $precision) . ' TB';
    } else {
        return $bytes . ' B';
    }
}

while ($docRows = mysql_fetch_array($docsQuery)) {
     $docID = $docRows['ID'];
     $docName = htmlspecialchars($docRows['docName']);
     $docDescription = htmlspecialchars($docRows['LEFT(docDescription, 50)']);
     $docPath = $docRows['filePath'];
     $origName = $docRows['origName'];
     $bytes = filesize($_SERVER['DOCUMENT_ROOT']."/documents/".$origName."");

    echo '<tr>
        <td><a href="'.$docPath.'">'.$docName.'</a> ('.bytesToSize($bytes).')</td>
        <td>';

    if (!empty($docDescription)) {
        echo(''.$docDescription.'...');
    }
     else {
    // don't show description if there isn't one
    }

    echo '</td>
        </tr>
    ';

} // end while