国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

php實(shí)現(xiàn)excel中rank函數(shù)功能的方法

Original 2017-02-09 09:57:44 464
abstract:本文實(shí)例講述了php實(shí)現(xiàn)excel中rank函數(shù)功能的方法。分享給大家供大家參考。具體分析如下:sql語(yǔ)句實(shí)現(xiàn)排名是像這樣的如:總分成績(jī)?yōu)?195,180,180,161,名次分別為1,2,3,4,遇到并列的情況也是按照順序的,而Excel函數(shù)rank排名得到的結(jié)果是1,2,2,4,遇到并列跳過(guò)中間的3下面的函數(shù)模擬的就是這種情況函數(shù)如下(不知道有沒(méi)有更好的實(shí)現(xiàn)方法):公式為: 名次=總?cè)藬?shù)--比

本文實(shí)例講述了php實(shí)現(xiàn)excel中rank函數(shù)功能的方法。分享給大家供大家參考。具體分析如下:

sql語(yǔ)句實(shí)現(xiàn)排名是像這樣的如:
總分成績(jī)?yōu)?195,180,180,161,名次分別為1,2,3,4,遇到并列的情況也是按照順序的,
而Excel函數(shù)rank排名得到的結(jié)果是1,2,2,4,遇到并列跳過(guò)中間的3
下面的函數(shù)模擬的就是這種情況
函數(shù)如下(不知道有沒(méi)有更好的實(shí)現(xiàn)方法):
公式為: 名次=總?cè)藬?shù)--比自己小的數(shù)的個(gè)數(shù)-這個(gè)分?jǐn)?shù)重復(fù)次數(shù)+1(加上自己)
得到名次的數(shù)組再根據(jù)對(duì)應(yīng)的id寫入到數(shù)據(jù)庫(kù),就實(shí)現(xiàn)rank的計(jì)算功能
(當(dāng)然這個(gè)也可以改成這樣195,180,180,165,名次是這樣的1,2,2,3)

//獲得一組數(shù)的名次的數(shù)組
function rank(array $array){
        foreach($array as $val){
                $repeat=get_array_repeats($val,$array);
                $num=gt_array_values($val,$array);
                $rank[]=count($array)-$num-$repeat+1;
        }
        return $rank;
}

//獲得比自己數(shù)小的個(gè)數(shù)
function gt_array_values($val,array $array){
        $num=0;
        for($i=0;$i<count($array);$i++){
                if($val>$array[$i]){
                        $num++;
                }
        }
        return $num;
}
//獲得這個(gè)數(shù)的重復(fù)次數(shù)
function get_array_repeats($string,array $array) {
        $count = array_count_values($array);
        foreach ($count as $key => $value) {
                 if ($key == $string) {
                  return $value;
                  }
         }
}

更多關(guān)于php實(shí)現(xiàn)excel中rank函數(shù)功能的方法請(qǐng)關(guān)注PHP中文網(wǎng)(www.miracleart.cn)其他文章!

Release Notes

Popular Entries