如何解决PHP的Facebook人搜索如何删除重复值?
|https://graph.facebook.com/search?q=tom&type=user&access_token=2227470867|2.AQD2FG3bzBMEiDV3.3600.1307905200.0-100001799728875|LowLfLcqSZ9YKujFEpIrlFNVZPQ
如何避免在facebook人物搜索中重复名字?在json代码中,有2个1。谢谢。
foreach ($status_list[\'data\'] as $data) {
echo $data[\'name\']; // not print the same name.
}
解决方法
这是如何删除重复项的快速混搭:
<?php
function existsInArray($list,$key,$value){
foreach($list as $lkey => $lvalue){
if($lvalue[$key] == $value){
return true;
}
}
return false;
}
$sortedUsers = array();
foreach($status_list[\'data\'] as $data){
if(!existsInArray($sortedUsers,\"id\",$data[\"id\"])){
$sortedUsers[] = $data;
}
}
这将遍历用户的数组,检查每个项目在排序后的数组中是否存在相同的ID。如果不存在,它将被添加到排序数组中。然后,您将获得$sortedUsers
,其中不包含任何重复项。
注意:但是,这仅仅是概念代码的证明。因此,可能有很多性能优化可以完成。另外,可能有一些内置功能可以用更少的用户定义代码来实现。我之所以这样做,是为了解释一下过程。
编辑:自从这个答案被接受以来,我觉得有义务展示比概念证明代码质量更高的东西。也因为在评论中提到它效率低下。
因此,这里有一个简单的修复方法可以使速度更快:
$sortedUsers = array();
foreach($status_list[\'data\'] as $data){
$sortedUsers[$data[\"id\"]] = $data;
}
这样,它只会覆盖重复项,并消除比较每个项目的整个过程。在最坏的情况下,这将是O(n),因为在最坏的情况下,概念证明代码为O(n ^(n / 2))。
, $names = Array();
foreach ($status_list[\'data\'] as $data) {
$names[] = $data[\'name\'];
}
$names = array_unique($names); // not print the same name.
foreach ($names as $name) {
echo $name;
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。