1

私は2つの異なる配列を持っています

配列 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
);

2 番目の配列 ($dateRanges) に array_flip を使用したので、シーケンス内の値を混乱させないでください。

日付の値を 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_columnarray_combinearray_walk

ありがとう

4

2 に答える 2

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;
});
于 2018-09-27T13:07:58.450 に答える