我有这个(貌似)简单的PHP问题:
我有一个关联数组(它反映了数据库表的结构,但这不相关,在这里),像这样:
----------------------------------
id | name | phone
----------------------------------
1 | alice | 12345678
3 | bob | 56789012
9 | zorro | 90123456
... | ... | ...
----------------------------------
我需要遍历数组以比较(比如检查没有两个人拥有相同的电话号码)每个其他所有密钥,避免重复检查,如check(1,3)和check(3,1) ......(我想我可以用等效的数学概念命名这些duplications
)。
<?php
$table = [
[
"id" => "1",
"name" => "alice",
"phone" => "12345678",
], [
[
"id" => "3",
"name" => "bob",
"phone" => "56789012",
], [
[
"id" => "9",
"name" => "zorro",
"phone" => "90123456",
],
];
?>
这就是我正在尝试的:
<?php
foreach ($table as $record1) {
foreach ($table as $record2) {
check($record1["phone"], $record2["phone"]);
}
}
?>
但当然这重复检查......
通常(例如在C language
中),我将按顺序迭代数组,从外部循环的当前索引旁边的索引开始内部循环...但是在PHP中我被告知我不能按顺序迭代一个关联数组......: - (
所以问题是:如何迭代PHP关联数组以将函数应用于任意一对键,避免排列?
答案 0 :(得分:1)
你可以像在C:
中那样做$len = count($table);
for($i = 0; $i < $len - 1; $i++)
for($j = $i + 1; $j < $len; $j++)
compare table[$i] and table[$j]
如果您的密钥不是连续的,则迭代密钥数组(这是顺序的)而不是实际的数组:
$keys = array_keys($table);
$len = count($keys);
for($i = 0; $i < $len - 1; $i++)
for($j = $i + 1; $j < $len; $j++)
compare table[keys[$i]] and table[keys[$j]]
答案 1 :(得分:0)
您可以使用in_array:
foreach ($table as $record1) {
if(in_array($record1["phone"], $table){
}
}
检查数组中是否存在当前值。在此处阅读更多内容:http://php.net/manual/en/function.in-array.php
答案 2 :(得分:0)
试试这个:)
<?php
$data = array(
array('id'=>'1','name'=>'test1','phone'=>'1231231234'),
array('id'=>'2','name'=>'test2','phone'=>'1231231235'),
array('id'=>'3','name'=>'test2','phone'=>'1231231234')
);
// sort and find duplicate numbers
$ch = array();
$duplicate = array();
foreach($data as $k=>$d){
if(in_array($d['phone'],$ch)){
$duplicate[] = $k;
}else{
$ch[$k]=$d['phone'];
}
}
// remove duplicated numbers from the initial table array
if($duplicate){
foreach($duplicate as $r)
unset($data[$r]);
}
// now we have only unique numbers
echo '<pre>';
print_r($data);
echo '</pre>';