PHP MySQL - нужно отобразить список файлов и их размер, отформатированный. Переопределить ошибку функции
Я застрял на чем-то простом для более опытных людей 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 ответа
Вам нужно определить свою функцию, а затем вызвать ее, если вы определяете функцию более одного раза, 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
Вы должны объявить свою функцию вне цикла, а затем использовать ее так же, как вы делаете.