3 回答
TA貢獻1824條經驗 獲得超8個贊
array_unique對于您手頭的問題,我真的懷疑這是從使用標志時從數組中刪除元素的方式來的?SORT_REGULAR,方法是:
整理它
如果相鄰項相等,則刪除它們
Proxy而且因為您的收藏中間確實有一個對象User,這可能會導致您遇到當前面臨的問題。
這似乎得到了sortPHP 文檔頁面警告的支持。
警告對具有混合類型值的數組進行排序時要小心,因為如果是
sort(),可能會產生意想不到的結果。sort_flagsSORT_REGULAR
現在對于一個可能的解決方案,這可能會給你帶來更多 Symfony 風味的東西。
它使用ArrayCollection?filterandcontains方法來過濾第二個集合,只添加第一個集合中不存在的元素。
為了完全完整,該解決方案還利用use語言結構將第二個傳遞ArrayCollection給所需的閉包函數filter。
這將導致一個新的ArrayCollection不包含重復的用戶。
public static function merge(Collection $a, Collection $b, bool $unique = false): Collection {
? if($unique){
? ? return new ArrayCollection(
? ? ? array_merge(
? ? ? ? $a->toArray(),
? ? ? ? $b->filter(function($item) use ($a){
? ? ? ? ? return !$a->contains($item);
? ? ? ? })->toArray()
? ? ? )
? ? );
? }
? return new ArrayCollection(array_merge($a->toArray(), $b->toArray()));
}
TA貢獻1808條經驗 獲得超4個贊
我知道你說你不想轉換為字符串,但我看到你還沒有出路,所以我建議你對serialize數組中的每個對象使用該函數,我沒有找到方法比較未轉換為數組或字符串的對象(如果您不熟悉字符串或數組,則不能嘗試轉換為二進制或十六進制,但我不知道是否可以轉換為二進制或十六進制而不轉換為字符串).
但是,如果你使用serialize,你可以在 php 的讀取數據中序列化對象,與其他序列化對象相比,這個方法 ( serialize) 是安全的,因為你可以做一個unserialize, 并再次獲得原始對象。
所以你可以序列化數組中的所有元素,然后,你可以array_unique像這樣使用:
<?php
header("Content-Type: application/json");
class MyClass
{
public $var1;
public $var2;
function __construct($var1, $var2)
{
$this->var1 = $var1;
$this->var2 = $var2;
}
}
$arr = [
"a",
"a",
[1,2,3],
"b",
[1,2,3],
new MyClass(1,1),
new MyClass(1,new MyClass(1,1)),
new MyClass(1,new MyClass(1,1)),
];
$arrSerilized = array_map("serialize", $arr);
var_dump(
array_map(
"unserialize",
array_unique(
$arrSerilized,
SORT_STRING
)
)
);
/* output:
array(5) {
[0]=>
string(1) "a"
[2]=>
array(3) {
[0]=>
int(1)
[1]=>
int(2)
[2]=>
int(3)
}
[3]=>
string(1) "b"
[5]=>
object(MyClass)#6 (2) {
["var1"]=>
int(1)
["var2"]=>
int(1)
}
[6]=>
object(MyClass)#7 (2) {
["var1"]=>
int(1)
["var2"]=>
object(MyClass)#8 (2) {
["var1"]=>
int(1)
["var2"]=>
int(1)
}
}
}
*/
希望這對你有幫助,祝你有美好的一天!
PS:你serialize可以在不同的變量類型中保存相同的值,比如1在"1"不同的php讀取數據中序列化
TA貢獻1830條經驗 獲得超3個贊
在不了解您的實體類的情況下,很難猜測為什么會這樣。但我想你的主要問題是__toString()method 。如果您尚未定義它,則應添加一個,以便它為每個實體對象返回一個唯一/不同的字符串。如果它已經定義,請確保它返回不同的字符串。
class User{
private $name;
function __construct($name){
$this->name=$name;
}
function __toString(){
return $this->name;
}
}
$user = [];
$users[] = new User("User1");
$users[] = new User("User2");
$users[] = new User("User3");
$user1= $users[0];
$users[]=$user1; //duplicate
echo(count(array_unique($users))); // output should be 3
鑒于有關實體類的信息有限,我可以猜到這里。
編輯:
閱讀您的編輯后,我猜您將自己鎖定在其中。Sincearray_unique將根據您傳遞的 sort_flag 嘗試將實體對象轉換為字符串或數字。更多關于array_unique。因此,您需要實現 __toString() 或添加一些公共屬性來定義對象對實體的唯一性,例如
class User{
public $id;
private $name;
function __construct($id,$name){
$this->id=$id;
$this->name=$name;
}
}
$user = [];
$users[] = new User(1,"User1");
$users[] = new User(2,"User2");
$users[] = new User(3,"User3");
$user1= $users[0];
$users[]=$user1; //duplicate
echo(count(array_unique($users, SORT_REGULAR))); // output should be 3
請注意公共財產$id和SORT_REGULAR旗幟。
- 3 回答
- 0 關注
- 186 瀏覽
添加回答
舉報
