gpt4 book ai didi

php - 排序 multidim 数组 : prioritize if column contains substring, 然后按第二列排序

转载 作者:可可西里 更新时间:2023-11-01 13:38:16 25 4
gpt4 key购买 nike

我目前正在创建一个由来自 mysql 查询的值组成的排序方法。

下面是数组的简要 View :

    Array
(
[0] => Array
(
['id'] = 1;
['countries'] = 'EN,CH,SP';
)
[1] => Array
(
['id'] = 2;
['countries'] = 'GE,SP,SV';
)
)

我已经成功地根据数字 id 值进行了正常的 usort,但我更想根据“国家”字段的内容对数组进行排序(如果它包含一个设置字符串,在这种情况下是国家代码) , 然后是 id 字段。

下面的片段是我的第一个想法,但我不知道如何将它合并到一个工作函数中:

in_array('EN', explode(",",$a['countries']) );

你会怎么做?

谢谢!


不幸的是,我真的无处可去。

这是我目前所拥有的,它只给我错误:uasort() [function.uasort]: Invalid comparison function

function compare($a, $b) {
global $usercountry;

if ( in_array($usercountry, $a['countries']) && in_array($usercountry, $a['countries']) ) {
$return = 0;
}

else if (in_array($usercountry, $a['countries'])) {
$return = 1;
}

else {
$return = -1;
}

return $return;


}

$array= usort($array, "compare");

有没有人可以给我提示如何继续?

最佳答案

就个人而言,我会结合使用自定义(匿名)函数 usort() .

编辑:重新 - 您的评论。希望这会让你走上正轨。此函数对同时具有 EN 或均不具有 EN 的元素给予同等优先级,或在只有一个具有 EN 时调整优先级。

usort($array,function ($a, $b) {
$ac = strpos($a['countries'],'EN');
$bc = strpos($b['countries'],'EN');
if (($ac !== false && $bc !== false) || ($ac == false && $bc == false)) {
return 0;
}
elseif ($ac !== false) {
return 1;
}
else {
return -1;
}
});

另一方面,如果两者都具有 EN,此函数将给予同等优先级,如果一个具有 EN,则给予更高的优先级,如果两者都没有 EN,则进行文本比较。

usort($array,function ($a, $b) {
$ac = strpos($a['countries'],'EN');
$bc = strpos($b['countries'],'EN');
if ($ac !== false && $bc !== false)) {
return 0;
}
elseif ($ac !== false) {
return 1;
}
elseif ($bc !== false) {
return -1;
}
else {
if ($a['countries'] == $b['countries']) {
return 0;
}
elseif($a['countries'] > $b['countries']) {
return 1;
}
else {
return -1;
}
}
});

再次,希望这会给你足够的方向,让你自己继续前进。如果您遇到任何问题,请随时发表更多评论,我会尽力提供帮助。 如果您想比较多个属性与权重,请注意:尝试一个时髦的开关 block ,例如

$ac = array_flip(explode(',',$a['countries']));
$bc = array_flip(explode(',',$b['countries']));
switch (true) {
case array_key_exists('EN',$ac) && !array_key_exists('EN',$bc):
return 1;
case array_key_exists('DE',$ac) && !array_key_exists('EN',$bc) && !array_key_exists('EN',$bc):
return 1;
// and so on
}

更多编辑!

其实我考虑的更多的是复数排序的问题,得出了如下解决方案,供大家引用。它将允许您根据出现在国家/地区索引中的关键字来定义数字排名。这是代码,包括示例:

示例数组

$array = array(
array(
'countries' => 'EN,DE,SP',
),
array(
'countries' => 'EN,CH,SP',
),
array(
'countries' => 'DE,SP,CH',
),
array(
'countries' => 'DE,SV,SP',
),
array(
'countries' => 'EN,SP,FR',
),
array(
'countries' => 'DE,FR,CH',
),
array(
'countries' => 'CH,EN,SP',
),

);

排序例程

$rankings = array(
'EN' => 10,
'SP' => 8,
'FR' => 7,
'DE' => 5,
'CH' => 3,
'SV' => 1,
);
usort($array, function (&$a, &$b) use ($rankings) {
if (isset($a['_score'])) {
$aScore = $a['_score'];
}
else {
$aScore = 0;
$aCountries = explode(',',$a['countries']);
foreach ($aCountries as $country) {
if (isset($rankings[$country])) {
$aScore += $rankings[$country];
}
}
$a['_score'] = $aScore;
}

if (isset($b['_score'])) {
$bScore = $b['_score'];
}
else {
$bScore = 0;
$bCountries = explode(',',$b['countries']);
foreach ($bCountries as $country) {
if (isset($rankings[$country])) {
$bScore += $rankings[$country];
}
}
$b['_score'] = $bScore;
}
if ($aScore == $bScore) {
return 0;
}
elseif ($aScore > $bScore) {
return -1;
}
else {
return 1;
}
});

注意:此代码会将排名最高的整体排序到数组的顶部。如果你想要相反的行为,改变这个:

    elseif ($aScore > $bScore) {

    elseif ($aScore < $bScore) {

请注意,大于号已更改为小于号。进行此更改将导致排名最低的条目被排序到数组的顶部。希望这一切对您有所帮助!

另请注意!

此代码将对您的数组做一个小改动,因为它将 _score 元素添加到每个数组。希望这不是问题,因为通过存储这个值,我实际上能够将速度提高一倍以上(在我的基准测试中,.00038-.00041 下降到 .00016-.00018)。如果不是,则删除检索缓存值的 if block ,让 else block 的内容每次都执行,当然存储分数值的部分除外。

顺便说一句,这是排序后数组的 var_export() 转储:

array (
0 => array (
'countries' => 'EN,SP,FR',
'_score' => 25,
),
1 => array (
'countries' => 'EN,DE,SP',
'_score' => 23,
),
2 => array (
'countries' => 'EN,CH,SP',
'_score' => 21,
),
3 => array (
'countries' => 'CH,EN,SP',
'_score' => 21,
),
4 => array (
'countries' => 'DE,SP,CH',
'_score' => 16,
),
5 => array (
'countries' => 'DE,FR,CH',
'_score' => 15,
),
6 => array (
'countries' => 'DE,SV,SP',
'_score' => 14,
),
)

尽情享受吧!

关于php - 排序 multidim 数组 : prioritize if column contains substring, 然后按第二列排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2059255/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com