php - 如何向多维数组添加值?
问题描述
I compare these two arrays:
$数组1:
array(3) {
[0]=>
array(10000) {
["12345"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 19:46:25"
["fileName"]=>
string(46) "monkey.jpg"
["path"]=>
string(149) "Volumes/animals/monkey.jpg"
["size"]=>
string(7) "2650752"
}
["678790"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 14:39:43"
["fileName"]=>
string(45) "elephant.jpg"
["path"]=>
string(171) "Volumes/animals/elephant.jpg"
["size"]=>
string(7) "2306688"
}
["23123"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 14:39:43"
["fileName"]=>
string(45) "fred.jpg"
["path"]=>
string(171) "Volumes/animals/fred.jpg"
["size"]=>
string(7) "2306688"
}
}
[1]=>
array(10000) {
["624245"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 19:46:25"
["fileName"]=>
string(46) "duck.jpg"
["path"]=>
string(149) "Volumes/animals/duck.jpg"
["size"]=>
string(7) "2650752"
}
["934522"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 14:39:43"
["fileName"]=>
string(45) "lora.jpg"
["path"]=>
string(171) "Volumes/animals/lora.jpg"
["size"]=>
string(7) "2306688"
}
["832452"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 14:39:43"
["fileName"]=>
string(45) "sam.jpg"
["path"]=>
string(171) "Volumes/animals/sam.jpg"
["size"]=>
string(7) "2306688"
}
}
[2]=>
array(1500) {
["234214"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 19:46:25"
["fileName"]=>
string(46) "chi.jpg"
["path"]=>
string(149) "Volumes/animals/chi.jpg"
["size"]=>
string(7) "2650752"
}
["942134"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 14:39:43"
["fileName"]=>
string(45) "ape.jpg"
["path"]=>
string(171) "Volumes/animals/ape.jpg"
["size"]=>
string(7) "2306688"
}
["234234"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 14:39:43"
["fileName"]=>
string(45) "cat.jpg"
["path"]=>
string(171) "Volumes/animals/cat.jpg"
["size"]=>
string(7) "2306688"
}
}
}
$数组2:
array(3) {
[0]=>
array(10000) {
["12345"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 19:46:25"
["fileName"]=>
string(46) "monkei.jpg"
["path"]=>
string(149) "Volumes/animals/monkey.jpg"
["size"]=>
string(7) "2650752"
}
["678790"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 14:39:43"
["fileName"]=>
string(45) "elephant.jpg"
["path"]=>
string(171) "Volumes/animals/elephant.jpg"
["size"]=>
string(7) "2306688"
}
["23123"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 14:39:43"
["fileName"]=>
string(45) "fred.jpg"
["path"]=>
string(171) "Volumes/animals/fred.jpg"
["size"]=>
string(7) "2306688"
}
}
[1]=>
array(10000) {
["624245"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 19:46:25"
["fileName"]=>
string(46) "duck.jpg"
["path"]=>
string(149) "Volumes/animals/duck.jpg"
["size"]=>
string(7) "2650752"
}
["934522"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 14:39:43"
["fileName"]=>
string(45) "lora.jpg"
["path"]=>
string(171) "Volumes/animals/lora.jpg"
["size"]=>
string(7) "2306688"
}
["832452"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 14:39:43"
["fileName"]=>
string(45) "sam.jpg"
["path"]=>
string(171) "Volumes/animals/sam.jpg"
["size"]=>
string(7) "2306688"
}
}
[2]=>
array(1500) {
["234214"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 19:46:25"
["fileName"]=>
string(46) "chi.jpg"
["path"]=>
string(149) "Volumes/animals/chi.jpg"
["size"]=>
string(7) "2650752"
}
["942134"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 14:39:43"
["fileName"]=>
string(45) "ape.jpg"
["path"]=>
string(171) "Volumes/animals/ape.jpg"
["size"]=>
string(7) "2306688"
}
["234234"]=>
array(5) {
["dateTime"]=>
string(19) "2016-10-12 14:39:43"
["fileName"]=>
string(45) "cat.jpg"
["path"]=>
string(171) "Volumes/animals/cat.jpg"
["size"]=>
string(7) "2306688"
}
}
}
我将它们与此功能进行比较:
function array_diff_assoc_recursive($array1, $array2){
foreach($array1 as $key => $value){
if(is_array($value)){
if(!isset($array2[$key])){
$difference[$key] = $value;
}
elseif(!is_array($array2[$key])){
$difference[$key] = $value;
}
else{
$new_diff = array_diff_assoc_recursive($value, $array2[$key]);
if($new_diff != FALSE)
{
$difference[$key] = $new_diff;
}
}
}
elseif(!isset($array2[$key]) || $array2[$key] != $value){
$difference[$key] = $value;
}
}
return !isset($difference) ? 0 : $difference;
}
echo "<pre>";
print_r(array_diff_assoc_recursive($array1, $array2));
echo "</pre>";
结果是:
array(1) {
[0]=>
array(1) {
["12345"]=>
array(1) {
["fileName"]=>
string(46) "monkey.jpg"
}
}
}
但是我需要的是,无论差异在哪里,我也总是需要在数组中的路径。我试图添加$value["path"]
到数组中$difference
,但不知道该怎么做。
我需要的结果是:
array(1) {
[0]=>
array(1) {
["12345"]=>
array(2) {
["fileName"]=>
string(46) "monkey.jpg"
["path"]=>
string(46) "Volumes/animals/monkey.jpg"
}
}
}
解决方案
试试这个
function array_diff_assoc_recursive($array1, $array2){
foreach($array1 as $key => $value){
if(is_array($value)){
if(!isset($array2[$key])){
$difference[$key] = $value;
$difference['path'] = $value['path'];
}
elseif(!is_array($array2[$key])){
$difference[$key] = $value;
$difference['path'] = $value['path'];
}
else{
$new_diff = array_diff_assoc_recursive($value, $array2[$key]);
if($new_diff != FALSE)
{
$difference[$key] = $new_diff;
$difference['path'] = $new_diff['path'];
}
}
}
elseif(!isset($array2[$key]) || $array2[$key] != $value){
$difference[$key] = $value;
}
}
return !isset($difference) ? 0 : $difference;
}
echo "<pre>";
print_r(array_diff_assoc_recursive($array1, $array2));
echo "</pre>";
推荐阅读
- excel - 如何根据excel中的特定条件向上和向下舍入数字?
- powerbi - POWER BI:我希望 DAX 公式在我的主表中找出组的第一个最高值和第二个最高值
- arrays - 求范围 [l:r] 中数字重复的频率 (r-l+1)/2 次
- javascript - 我只想对这部分代码 ${a}\_${b} 使用 repeat(4) 并从重复中排除下划线以在评论中获得答案
- reactjs - 未出现在 WebStorm 中的 React Tailwind CSS 应用程序上的类的自动完成
- callback - 无法捕获 MQTT 日志回调
- django - 在 pandas 数据框行 pandas() 中动态访问值
- python - 我正在尝试使用 python 脚本将文件写入我的公司共享点,但我无法让它工作
- javascript - 如何制作一个更改另一个元素的类的按钮?
- amazon-web-services - IP 地址(在源列下)在 AWS 安全组的入站和出站规则中代表/或意味着什么?