php计算结果排序,php-按从数组计算出的值对数组进行排序
我从阵列中的数据库中获得了用户的经纬度
我有我的经纬
现在,我要计算距离并使用该距离对数据库中的用户进行排序
$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-按从数组计算出的值对数组进行排序相关推荐
- php某列为键数组为值,PHP 将二维数组中某列值作为数组的键名 -- 超实用
有时候,想通过数组的中某字段值, 然后再在二维数组中获取存在该字段值的数组: 一般能想到的就是foreach 遍历比较一下跟该字段值一样,就获取到想要的数组,如下: //测试二维数组 $arr =ar ...
- php查找二维数组值,根据二维数组某个字段的值查找数组
根据二维数组某个字段的值查找数组 /** * @param $array * @param $index * @param $value * @return mixed */ public funct ...
- php 数组插入键和值,php数组中键和值的关系
php数组中键和值的关系 ● php数组中键可以重复,但重复的键的值会被后面的覆盖. ● php数组中值不同键的值可以重复. ● php数组中元素可以有键也可以没有键.<?php // 键可以重 ...
- php 数组指向下一个值,比较数组值并根据自定义值(PHP)在数组中查找下一个值 - php...
我正在尝试比较数组中的值,然后根据所选值在数组中选择下一个值. 例如 array(05:11,05:21,05:24,05:31,05:34,05:41,05:44,05:50,05:54); 如果搜 ...
- php 根据键值合并数组,PHP根据键值合并数组
我们现在来分析一下在PHP开发过程中,如何合并两个数组,并且将相同键值的元素合并在一起. 示例1 最简单的合并方式$a = [ 1=>'a', 2=>'b', 3=>'c' ]; $ ...
- 60 无键值Json数组和有键值json数组实验
1.引言 特殊的无key值的json数组今天遇到了,所以研究了会才知道怎么生成和解析这种无键值的json数组.下面我们来看看今天的实验. 2.json生成数组实验 今天的实验就是生成这样 ...
- java基础——求数组长度、遍历数组、求最值和数组元素反转
一.求数组长度 获取数组的长度的格式: 数组名称.length这将会得到一个int数字,代表数组的长度.数组一旦创建,程序运行期间,长度不可改变. 代码如下: public class Demo08 ...
- 冒泡排序--通过冒泡算法让数组中最大的值成为数组中最后一个值
var nums = [];//定义一个空数组for(var i=0;i<5;i++){//要用户输入五个数字,循环5次nums[i] = parseInt(prompt('请输入数字'));/ ...
- php多维数组打印出最长的数组,将php中的多维数组打印到html表中
所以我在将多维数组打印到表格时遇到了一些麻烦.现在我 Array ( [0] => stdClass Object ( [id] => 00fa4033-421f-48d9-bc69-a0 ...
最新文章
- 从底层理解Python的执行
- 前一个参数作为下个参数结果
- columnproperty server sql_导出SQL Server数据库表中字段的说明/备注
- Vasya and Robot
- 绕过mysql的id:32933 BUG 实现order by limit 正常取数据.
- Word中摘要和正文同时分栏后,正文跑到下一页,怎么办?或Word分栏后第一页明明有空位后面的文字却自动跳到第二页了,怎么办?...
- 常用IE浏览器的兼容处理(方法一)
- E/Trace: error opening trace file: No such file or directory
- 腾讯优图升级为计算机视觉研发中心,与《科学》宣布战略合作
- 中台“不火”了,企业数智转型如何破圈?
- php各安装包中TS和NTS及SRC/VC6|VC9|VC11|VC14|VC15版本区别意思详解(转)
- 浏览器背后的运行机制
- openpyxl 添加分页符
- EXP6 信息搜集与漏洞扫描 20154328 常城
- UE4 虚幻 常用的流程控制蓝图节点介绍
- git、githut、码云概念和使用,md文件编辑,
- 经济学常识之破窗谬论
- 斜杠青年:人生的多种可能
- java月亮代码_Java编程实现月食简单代码分享
- 众妙之门玄之又玄,游戏系统中的伪随机(Pseudo-Randomization)和真随机(True-Randomization)算法实现Python3
热门文章
- 揭秘阿里云EB级大数据计算引擎MaxCompute
- 黑科技揭秘:网红“天空物联网飞艇”服务范围为何能突破30公里
- 数据结构与算法、讲解、动态规划一脸懵?看完之后轻松掌握!
- 云计算管理工具:根植热土
- mysql怎么跳出while循环_mysql while,loop,repeat循环,符合条件跳出循环
- html的语义化面试题,前端面试题-HTML结构语义化
- 数组正遍历,数组倒遍历
- css h5移动端背景铺满
- SpringBoot 整合 Spring Cloud Alibaba Nacos 连通性+负载均衡
- docker 中用docker 启动应用访问docker中的mysql