我有两个不同的数组
数组1:
$result = array(
"2018-08-30" => 8
"2018-08-31" => 2
"2018-09-04" => 4
"2018-09-20" => 1
"2018-09-24" => 1
"2018-09-27" => 2
);
和
数组2
$dateRanges = array(
"2018-08-28" => 0
"2018-08-29" => 1
"2018-08-30" => 2
"2018-08-31" => 3
"2018-09-01" => 4
"2018-09-02" => 5
"2018-09-03" => 6
"2018-09-04" => 7
"2018-09-05" => 8
"2018-09-06" => 9
"2018-09-07" => 10
"2018-09-08" => 11
"2018-09-09" => 12
"2018-09-10" => 13
"2018-09-11" => 14
"2018-09-12" => 15
"2018-09-13" => 16
"2018-09-14" => 17
"2018-09-15" => 18
"2018-09-16" => 19
"2018-09-17" => 20
"2018-09-18" => 21
"2018-09-19" => 22
"2018-09-20" => 23
"2018-09-21" => 24
"2018-09-22" => 25
"2018-09-23" => 26
"2018-09-24" => 27
"2018-09-25" => 28
"2018-09-26" => 29
"2018-09-27" => 30
);
我已将array_flip用于第二个数组($ dateRanges),所以请不要混淆序列中给出的值。
我想将日期值从Array1分配给Array2;
预期结果:
$dateRanges = array(
"2018-08-28" => 0
"2018-08-29" => 0
"2018-08-30" => 8
"2018-08-31" => 2
"2018-09-01" => 0
"2018-09-02" => 0
"2018-09-03" => 0
"2018-09-04" => 4
"2018-09-05" => 0
"2018-09-06" => 0
"2018-09-07" => 0
"2018-09-08" => 0
"2018-09-09" => 0
"2018-09-10" => 0
"2018-09-11" => 0
"2018-09-12" => 0
"2018-09-13" => 0
"2018-09-14" => 0
"2018-09-15" => 0
"2018-09-16" => 0
"2018-09-17" => 0
"2018-09-18" => 0
"2018-09-19" => 0
"2018-09-20" => 1
"2018-09-21" => 0
"2018-09-22" => 0
"2018-09-23" => 0
"2018-09-24" => 1
"2018-09-25" => 0
"2018-09-26" => 0
"2018-09-27" => 2
);
我已经使用foreach循环完成此操作,在该循环中我检查我的日期是否存在于$dateRanges
数组中,但是我想知道是否存在使用array_column
或{{1}的快捷方式}或array_combine
函数。
谢谢
答案 0 :(得分:2)
您可以结合使用array_map()
和array_merge()
$newArr = array_merge(array_map(function($v){return 0;}, $dateRanges), $result);
在demo中查看结果
答案 1 :(得分:1)
以下方法应该起作用,将值从$array1
复制到$array2
或在不存在值的情况下设置0
。
我尚未测试此代码,因此可能需要进行一些调整。
$array1 = array(/*...*/);
$array2 = array(/*...*/);
array_walk($array2, function (&$v, $k) use ($array1) {
if (isset($array1[$k]))
$v = $array1[$k];
else
$v = 0;
});