我查看了 Math 套件中提供的百分位數程式碼。我將其結果與 Excel 的百分位數函數進行比較,發現結果並不相符。因此,我編寫了自己的百分位數函數,並使用 Excel 的百分位數函數驗證了結果。
提供給需要在 PHP 中使用 Excel 百分位數計算方式的各位:
<?php
function mypercentile($data,$percentile){
if( 0 < $percentile && $percentile < 1 ) {
$p = $percentile;
}else if( 1 < $percentile && $percentile <= 100 ) {
$p = $percentile * .01;
}else {
return "";
}
$count = count($data);
$allindex = ($count-1)*$p;
$intvalindex = intval($allindex);
$floatval = $allindex - $intvalindex;
sort($data);
if(!is_float($floatval)){
$result = $data[$intvalindex];
}else {
if($count > $intvalindex+1)
$result = $floatval*($data[$intvalindex+1] - $data[$intvalindex]) + $data[$intvalindex];
else
$result = $data[$intvalindex];
}
return $result;
}
?>
以上程式碼可能不夠簡潔,但它解決了我的問題。
yuvaraj