在5星评级系统中将评级转换为百分比

时间:2015-06-21 11:49:42

标签: php math formulas

我的一个项目中有一个5星评级系统。我想将每颗星转换为百分比值。

这是我的数据库

star1

star2

star3

star4

star5

tot_stars

average

我用来获得评分的计算

$cal = ($star1*1 + $star2*2 + $star3*3 + $star4*4 + $star5*5)/$total_stars;

$avg = number_format($cal, 2);

我想知道的是将每颗星作为百分比的数学算法

示例:Yelp.com在其网站上执行此操作

3 个答案:

答案 0 :(得分:5)

如果您的目标是获得(例如)1星级的评分百分比,那么只需将star1除以评分数(我猜是tot_stars,尽管名称似乎暗示否则)。这会让你占一席之地;乘以100得到一个百分比。

因此,例如,让数据库进行数学运算:

SELECT star1, star1 * 100 / tot_stars AS percent1, 
       star2, star2 * 100 / tot_stars AS percent2, 
       star3, star3 * 100 / tot_stars AS percent3, 
       star4, star4 * 100 / tot_stars AS percent4, 
       star5, star5 * 100 / tot_stars AS percent5
  FROM starsTable

或在PHP中执行:

<?php     
// Example data
$star1 = 1;
$star2 = 5;
$star3 = 7;
$star4 = 10;
$star5 = 8;

$tot_stars = $star1 + $star2 + $star3 + $star4 + $star5;

for ($i=1;$i<=5;++$i) {
  $var = "star$i";
  $count = $$var;
  $percent = $count * 100 / $tot_stars;
  for ($j=1;$j<=5;++$j) {
    echo $j <= $i ? "☆ " : "  ";
  }
  printf("\t%2d (%5.2f%%)\n", $count, $percent,2);
}
?>

哪个输出:

☆            1 ( 3.23%)
☆ ☆          5 (16.13%)
☆ ☆ ☆        7 (22.58%)
☆ ☆ ☆ ☆     10 (32.26%)
☆ ☆ ☆ ☆ ☆    8 (25.81%)

答案 1 :(得分:2)

我提出了一个解决方案,它是一个函数,它获取一个数组,其中有星星作为值。我们计算总值,然后逐个计算百分比。我们返回百分比。每个百分比将对应于具有相同索引的输入中的星号。

function getPercentages($inputValues) {
    $totalValues = 0;
    foreach ($inputValues as $inputValue) {
        $totalValues += $inputValue;
    }
    $outputValues = array();
    foreach ($inputValues as $key => $inputValue) {
        $outputValues[$key] = 100 * $inputValue / $totalValues;
    }
    return $outputValues;
}

答案 2 :(得分:0)

好吧,我建议你在数据库中进行数学计算,然后让它返回一个浮点值。这样,您可以轻松地以“百分比”样式显示星星。

示例:

SELECT (CAST(
          (star1*1) + (star2*2) + (star3)*3 + (star4*4) + (star5*5) 
        as float)/15) as percentageStars

正如您的展示示例:

  • 5星:80-100
  • 4星:60-80
  • 3星:40-60
  • 2星:20-40
  • 1星:0-20

由于您知道1星跨越20点,因此对于应答星而言,您可以轻松地将1点作为5%来填充因子。我想你会尝试将它转换成css属性以显示星星的颜色,对吗?

实施例: 你得到了评分......好吧说得好吧4.8。这意味着您可以将完整值用作总星数,这意味着4. Afterwars您可以使用modulo(%1)来获取剩余值。例如,可以将此剩余值乘以100以获得css的百分比填充因子。

式: 4.8%1 = 0.8 * 100 = 80

希望这会对你有帮助吗?