我坚持认为对于经验丰富的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
答案 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