加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

PHP编程:php实现excel中rank函数功能的方法

发布时间:2020-12-13 02:21:12 所属栏目:PHP教程 来源:网络整理
导读:《php实现excel中rank函数功能的方法》要点: 本文介绍了php实现excel中rank函数功能的方法,希望对您有用。如果有疑问,可以联系我们。 PHP学习 本篇章节讲解php实现excel中rank函数功能的办法.供大家参考研究.具体分析如下: sql语句实现排名是像

《php实现excel中rank函数功能的方法》要点:
本文介绍了php实现excel中rank函数功能的方法,希望对您有用。如果有疑问,可以联系我们。

PHP学习本篇章节讲解php实现excel中rank函数功能的办法.分享给大家供大家参考.具体分析如下:

sql语句实现排名是像这样的如:
总分成绩为 195,180,161,名次分别为1,2,3,4,遇到并列的情况也是依照顺序的,
而Excel函数rank排名得到的结果是1,遇到并列跳过中间的3
下面的函数模拟的就是这种情况
函数如下(不知道有没有更好的实现方法):
公式为: 名次=总人数--比自己小的数的个数-这个分数重复次数+1(加上自己)
得到名次的数组再根据对应的id写入到数据库,就实现rank的计算功能
(当然这个也可以改成这样195,165,名次是这样的1,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;
}

//获得比自己数小的个数
function gt_array_values($val,array $array){
??????? $num=0;
??????? for($i=0;$i<count($array);$i++){
??????????????? if($val>$array[$i]){
??????????????????????? $num++;
??????????????? }
??????? }
??????? return $num;
}
//获得这个数的重复次数

function get_array_repeats($string,array $array) {
??????? $count = array_count_values($array);
??????? foreach ($count as $key => $value) {
???????????????? if ($key == $string) {
????????????????? return $value;
????????????????? }
???????? }
}

希望本文所述对大家的php程序设计有所赞助.

编程之家培训学院每天发布《php实现excel中rank函数功能的方法》等实战技能,PHP、MYSQL、LINUX、APP、JS,CSS全面培养人才。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读