php實(shí)現(xiàn)excel中rank函數(shù)功能的方法
本文實(shí)例講述了php實(shí)現(xiàn)excel中rank函數(shù)功能的方法。分享給大家供大家參考。具體分析如下:
sql語句實(shí)現(xiàn)排名是像這樣的如:
總分成績?yōu)?195,180,180,161,名次分別為1,2,3,4,遇到并列的情況也是按照順序的,
而Excel函數(shù)rank排名得到的結(jié)果是1,2,2,4,遇到并列跳過中間的3
下面的函數(shù)模擬的就是這種情況
函數(shù)如下(不知道有沒有更好的實(shí)現(xiàn)方法):
公式為: 名次=總?cè)藬?shù)--比自己小的數(shù)的個(gè)數(shù)-這個(gè)分?jǐn)?shù)重復(fù)次數(shù)+1(加上自己)
得到名次的數(shù)組再根據(jù)對應(yīng)的id寫入到數(shù)據(jù)庫,就實(shí)現(xiàn)rank的計(jì)算功能
(當(dāng)然這個(gè)也可以改成這樣195,180,180,165,名次是這樣的1,2,2,3)
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;
}
}
}
希望本文所述對大家的php程序設(shè)計(jì)有所幫助。
相關(guān)文章
PHP回調(diào)函數(shù)與匿名函數(shù)實(shí)例詳解
這篇文章主要介紹了PHP回調(diào)函數(shù)與匿名函數(shù),結(jié)合實(shí)例形式分析了php回調(diào)函數(shù)與匿名函數(shù)的具體功能、用法及相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-08-08PHP連接MySQL數(shù)據(jù)庫的三種方式實(shí)例分析【mysql、mysqli、pdo】
這篇文章主要介紹了PHP連接MySQL數(shù)據(jù)庫的三種方式,結(jié)合實(shí)例形式分析了PHP基于mysql、mysqli、pdo三種方式連接MySQL數(shù)據(jù)庫的相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2019-11-11Yii PHP Framework實(shí)用入門教程(詳細(xì)介紹)
本篇文章是對Yii PHP Framework實(shí)用入門教程進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06基于yaf框架和uploadify插件,做的一個(gè)導(dǎo)入excel文件,查看并保存數(shù)據(jù)的功能
本文主要介紹了基于yaf框架和uploadify插件,做的一個(gè)導(dǎo)入excel文件,查看并保存數(shù)據(jù)的功能的思路與方法。具有很好的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01通過實(shí)例解析PHP數(shù)據(jù)類型轉(zhuǎn)換方法
這篇文章主要介紹了通過實(shí)例解析PHP數(shù)據(jù)類型轉(zhuǎn)換方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07PHP統(tǒng)計(jì)目錄大小的自定義函數(shù)分享
這篇文章主要介紹了PHP統(tǒng)計(jì)目錄大小的自定義函數(shù)分享,本文使用遞歸方法統(tǒng)計(jì)一個(gè)目錄中所有文件的大小,需要的朋友可以參考下2014-11-11PHP導(dǎo)出EXCEL快速開發(fā)指南--PHPEXCEL的使用詳解
本篇文章是對PHPEXCEL的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06