$a = Array
(
Array (
'cid' => 1,
'cname' => '关于'
),
Array (
'cid' => 7,
'cname' => '简介'
),
Array (
'cid' => 8,
'cname' => '文化'
),
Array (
'cid' => 9,
'cname' => '动态'
)
);
$b = Array
(
Array (
'cid' => 1,
'cname' => '关于'
),
Array (
'cid' => 2,
'cname' => '歌剧'
),
Array (
'cid' => 3,
'cname' => '美剧'
),
Array (
'cid' => 4,
'cname' => '视频'
),
Array (
'cid' => 5,
'cname' => '娱乐'
),
Array (
'cid' => 6,
'cname' => '联系'
),
Array (
'cid' => 7,
'cname' => '简介'
),
Array (
'cid' => 8,
'cname' => '文化'
),
Array (
'cid' => 9,
'cname' => '动态'
)
);
$c = Array
(
Array (
'cid' => 1,
'cname' => '关于'
),
Array (
'cid' => 7,
'cname' => '简介'
),
Array (
'cid' => 8,
'cname' => '文化'
),
Array (
'cid' => 9,
'cname' => '动态'
),
Array (
'cid' => 2,
'cname' => '歌剧'
),
Array (
'cid' => 3,
'cname' => '美剧'
),
Array (
'cid' => 4,
'cname' => '视频'
),
Array (
'cid' => 5,
'cname' => '娱乐'
),
Array (
'cid' => 6,
'cname' => '联系'
)
);已知$a,参照$a把$b排序成$c的样子。
$a = Array
(
Array (
'cid' => 1,
'cname' => '关于'
),
Array (
'cid' => 7,
'cname' => '简介'
),
Array (
'cid' => 8,
'cname' => '文化'
),
Array (
'cid' => 9,
'cname' => '动态'
)
);
$b = Array
(
Array (
'cid' => 1,
'cname' => '关于'
),
Array (
'cid' => 2,
'cname' => '歌剧'
),
Array (
'cid' => 3,
'cname' => '美剧'
),
Array (
'cid' => 4,
'cname' => '视频'
),
Array (
'cid' => 5,
'cname' => '娱乐'
),
Array (
'cid' => 6,
'cname' => '联系'
),
Array (
'cid' => 7,
'cname' => '简介'
),
Array (
'cid' => 8,
'cname' => '文化'
),
Array (
'cid' => 9,
'cname' => '动态'
)
);
$c = Array
(
Array (
'cid' => 1,
'cname' => '关于'
),
Array (
'cid' => 7,
'cname' => '简介'
),
Array (
'cid' => 8,
'cname' => '文化'
),
Array (
'cid' => 9,
'cname' => '动态'
),
Array (
'cid' => 2,
'cname' => '歌剧'
),
Array (
'cid' => 3,
'cname' => '美剧'
),
Array (
'cid' => 4,
'cname' => '视频'
),
Array (
'cid' => 5,
'cname' => '娱乐'
),
Array (
'cid' => 6,
'cname' => '联系'
)
);已知$a,参照$a把$b排序成$c的样子。
使用自定义排序函数usort来一发
<?php
class SortByArray {
public $ref;
public $array;
public function __construct($ref,$array){
$this->ref = $ref;
$this->array = $array;
usort($this->array,function($t1,$t2){
$p1 = array_search($t1,$this->ref);
$p2 = array_search($t2,$this->ref);
if(($p1===false||$p1===null) && ($p2===false||$p2===null))
return array_search($t1,$this->array)<array_search($t2,$this->array) ? -1 :1;
if($p1===$p2) return 0;
if($p1===false||$p1===null) return 1;
if($p2===false||$p2===null) return -1;
return $p1<$p2 ? -1 : 1;
});
}
}
//----------------------
$res = new SortByArray($a,$b);
print_r($res->array);
?>
这个应该是多维数组排序问题,php中的 array_multisort可以用于多维数组排序。
具体实现代码就不写了,可以看看手册自己琢磨一下。
婚纱影楼小程序提供了一个连接用户与影楼的平台,相当于影楼在微信的官网。它能帮助影楼展示拍摄实力,记录访客数据,宣传优惠活动。使用频率高,方便传播,是影楼在微信端宣传营销的得力助手。功能特点:样片页是影楼展示优秀摄影样片提供给用户欣赏并且吸引客户的。套系页是影楼根据市场需求推出的不同套餐,用户可以按照自己的喜好预定套系。个人中心可以查看用户预约的拍摄计划,也可以获取到影楼的联系方式。
0
/**
* [oneArrayTo 二维数组按某个数组值排序 一对多]
* @param [type] $a [参照数组]
* @param [type] $b [这个是要被排序的数组]
* @param [type] $keyword [键值]
* @return [type] [description]
*/
function oneArrayTo($a,$b,$keyword)
{
$newa = array();
foreach ($a as $key => $value) {
$newa[] = $value[$keyword];
}
$newa = array_flip($newa);
$newb = array();
foreach ($b as $key => $value) {
$newb[] = $value[$keyword];
}
$newb = array_flip($newb);
$d = $newb;
foreach ($newb as $k => $v) {
foreach ($newa as $key => $value) {
if($key == $k) {
unset($d[$k]);
}
}
}
$c = array_flip($newa);
$d = array_flip($d);
$p = array_merge($c,$d);
$p = array_flip($p);
$newbb = array();
foreach ($b as $key => $value) {
$newbb[$value[$keyword]] = $value;
}
$g = array();
foreach ($p as $key => $value) {
$g[] = $newbb[$key];
}
return $g;
}自己写好了,虽然是笨方法。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
C++高性能并发应用_C++如何开发性能关键应用
Java AI集成Deep Java Library_Java怎么集成AI模型部署
Golang后端API开发_Golang如何高效开发后端和API
Python异步并发改进_Python异步编程有哪些新改进
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全
Java GraalVM原生镜像构建_Java怎么用GraalVM构建高效原生镜像
Python FastAPI异步API开发_Python怎么用FastAPI构建异步API
C++现代C++20/23/26特性_现代C++有哪些新标准特性如modules和coroutines
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号