我从阵列中的数据库中获得了用户的经纬度

我有我的经纬

现在,我要计算距离并使用该距离对数据库中的用户进行排序

$mylat = $_SESSION['lat'];

$mylng = $_SESSION['lng'];

$statement = $pdo->prepare("SELECT * FROM users");

$statement->execute();

$users = $statement->fetchAll();

foreach($users as $row){

$dist = 0.0;

$x1 = $mylng;

$x2 = $row['lng'];

$y1 = $mylat;

$y2 = $row['lat'];

$dist = acos(sin($x1=deg2rad($x1))*sin($x2=deg2rad($x2))+cos($x1)*cos($x2)*cos(deg2rad($y2) - deg2rad($y1)))*(6378.137);

$distn = FLOOR ( ROUND($dist,1) * 2 ) / 2 ;

}

sort($distn);

foreach ($users as $row) {

$dist = 0.0;

$x1 = $mylng;

$x2 = $row['lng'];

$y1 = $mylat;

$y2 = $row['lat'];

$dist = acos(sin($x1=deg2rad($x1))*sin($x2=deg2rad($x2))+cos($x1)*cos($x2)*cos(deg2rad($y2) - deg2rad($y1)))*(6378.137);

$distn = FLOOR ( ROUND($dist,1) * 2 ) / 2 ;

echo $row['username'];

echo $distn;

}

因此,在第一个foreach中,我计算了每个用户到我的距离.

比我想对与我的距离后的用户进行排序并显示它们

那里有我的名字,也有我的距离.

user1 0.5km distance

user2 1km distance

但是我不会工作.

谢谢你的帮助 :)

解决方法:

创建一个距离函数:

function getDistance ($lat, $lon)

{

global $mylng, $mylat;

$x1 = deg2rad($mylng);

$x2 = deg2rad($lon);

$y1 = deg2rad($mylat);

$y2 = deg2rad($lat);

$dist = acos(sin($x1)*sin($x2)+cos($x1)*cos($x2)*cos($y2 - $y1))*(6378.137);

return $dist;

}

创建一个比较函数:

function compareDistance ($user1, $user2)

{

return getDistance ($user1['lat'], $user1['lng']) - getDistance ($user2['lat'], $user2['lng']);

}

然后,您可以通过uasort传递数组:

uasort ($users, 'compareDistance');

编辑:

您的程序可以被重写:

function getDistance ($lat, $lon)

{

global $mylng, $mylat;

$x1 = deg2rad($mylng);

$x2 = deg2rad($lon);

$y1 = deg2rad($mylat);

$y2 = deg2rad($lat);

$dist = acos(sin($x1)*sin($x2)+cos($x1)*cos($x2)*cos($y2 - $y1))*(6378.137);

return $dist;

}

function compareDistance ($user1, $user2)

{

return getDistance ($user1['lat'], $user1['lng']) - getDistance ($user2['lat'], $user2['lng']);

}

$mylat = $_SESSION['lat'];

$mylng = $_SESSION['lng'];

$statement = $pdo->prepare("SELECT * FROM users");

$statement->execute();

$users = $statement->fetchAll();

uasort ($users, 'compareDistance');

foreach ($users as $row) {

$dist = getDistance ($row['lat'], $row['lng']);

$distn = floor(round($dist,1) * 2) / 2 ;

echo $row['username']. ": " . $distn . "km distance";

}

标签:php,arrays,sorting,floating-point

来源: https://codeday.me/bug/20191012/1902470.html

php计算结果排序,php-按从数组计算出的值对数组进行排序相关推荐

  1. php某列为键数组为值,PHP 将二维数组中某列值作为数组的键名 -- 超实用

    有时候,想通过数组的中某字段值, 然后再在二维数组中获取存在该字段值的数组: 一般能想到的就是foreach 遍历比较一下跟该字段值一样,就获取到想要的数组,如下: //测试二维数组 $arr =ar ...

  2. php查找二维数组值,根据二维数组某个字段的值查找数组

    根据二维数组某个字段的值查找数组 /** * @param $array * @param $index * @param $value * @return mixed */ public funct ...

  3. php 数组插入键和值,php数组中键和值的关系

    php数组中键和值的关系 ● php数组中键可以重复,但重复的键的值会被后面的覆盖. ● php数组中值不同键的值可以重复. ● php数组中元素可以有键也可以没有键.<?php // 键可以重 ...

  4. php 数组指向下一个值,比较数组值并根据自定义值(PHP)在数组中查找下一个值 - php...

    我正在尝试比较数组中的值,然后根据所选值在数组中选择下一个值. 例如 array(05:11,05:21,05:24,05:31,05:34,05:41,05:44,05:50,05:54); 如果搜 ...

  5. php 根据键值合并数组,PHP根据键值合并数组

    我们现在来分析一下在PHP开发过程中,如何合并两个数组,并且将相同键值的元素合并在一起. 示例1 最简单的合并方式$a = [ 1=>'a', 2=>'b', 3=>'c' ]; $ ...

  6. 60 无键值Json数组和有键值json数组实验

    1.引言 特殊的无key值的json数组今天遇到了,所以研究了会才知道怎么生成和解析这种无键值的json数组.下面我们来看看今天的实验. 2.json生成数组实验        今天的实验就是生成这样 ...

  7. java基础——求数组长度、遍历数组、求最值和数组元素反转

    一.求数组长度 获取数组的长度的格式: 数组名称.length这将会得到一个int数字,代表数组的长度.数组一旦创建,程序运行期间,长度不可改变. 代码如下: public class Demo08 ...

  8. 冒泡排序--通过冒泡算法让数组中最大的值成为数组中最后一个值

    var nums = [];//定义一个空数组for(var i=0;i<5;i++){//要用户输入五个数字,循环5次nums[i] = parseInt(prompt('请输入数字'));/ ...

  9. php多维数组打印出最长的数组,将php中的多维数组打印到html表中

    所以我在将多维数组打印到表格时遇到了一些麻烦.现在我 Array ( [0] => stdClass Object ( [id] => 00fa4033-421f-48d9-bc69-a0 ...

最新文章

  1. 从底层理解Python的执行
  2. 前一个参数作为下个参数结果
  3. columnproperty server sql_导出SQL Server数据库表中字段的说明/备注
  4. Vasya and Robot
  5. 绕过mysql的id:32933 BUG 实现order by limit 正常取数据.
  6. Word中摘要和正文同时分栏后,正文跑到下一页,怎么办?或Word分栏后第一页明明有空位后面的文字却自动跳到第二页了,怎么办?...
  7. 常用IE浏览器的兼容处理(方法一)
  8. E/Trace: error opening trace file: No such file or directory
  9. 腾讯优图升级为计算机视觉研发中心,与《科学》宣布战略合作
  10. 中台“不火”了,企业数智转型如何破圈?
  11. php各安装包中TS和NTS及SRC/VC6|VC9|VC11|VC14|VC15版本区别意思详解(转)
  12. 浏览器背后的运行机制
  13. openpyxl 添加分页符
  14. EXP6 信息搜集与漏洞扫描 20154328 常城
  15. UE4 虚幻 常用的流程控制蓝图节点介绍
  16. git、githut、码云概念和使用,md文件编辑,
  17. 经济学常识之破窗谬论
  18. 斜杠青年:人生的多种可能
  19. java月亮代码_Java编程实现月食简单代码分享
  20. 众妙之门玄之又玄,游戏系统中的伪随机(Pseudo-Randomization)和真随机(True-Randomization)算法实现Python3

热门文章

  1. 揭秘阿里云EB级大数据计算引擎MaxCompute
  2. 黑科技揭秘:网红“天空物联网飞艇”服务范围为何能突破30公里
  3. 数据结构与算法、讲解、动态规划一脸懵?看完之后轻松掌握!
  4. 云计算管理工具:根植热土
  5. mysql怎么跳出while循环_mysql while,loop,repeat循环,符合条件跳出循环
  6. html的语义化面试题,前端面试题-HTML结构语义化
  7. 数组正遍历,数组倒遍历
  8. css h5移动端背景铺满
  9. SpringBoot 整合 Spring Cloud Alibaba Nacos 连通性+负载均衡
  10. docker 中用docker 启动应用访问docker中的mysql