3

次の最初の配列のようなオブジェクトを含む配列があります。

Array
(
[1] => stdClass Object
    (
        [matchID] => 1
        [tm] => 2014-01-16 08:55:13
        [playertm] => 2014-01-16 08:55:14
    )

[2] => stdClass Object
    (
        [matchID] => 2
        [tm] => 2014-01-16 09:53:50
        [playertm] => 2014-01-16 09:53:52
    )

[3] => stdClass Object
    (
        [matchID] => 3
        [tm] => 2014-01-16 09:58:49
        [playertm] => 2014-01-16 09:58:57
    )

[4] => stdClass Object
    (
        [matchID] => 4
        [tm] => 2014-01-17 08:44:34
        [playertm] => 2014-01-17 08:44:35
    )
)

2 番目の配列:

Array
(
[3] => stdClass Object
    (
        [matchID] => 3
        [tm] => 2014-01-16 09:58:49
        [playertm] => 2014-01-16 09:58:57
    )

[4] => stdClass Object
    (
        [matchID] => 4
        [tm] => 2014-01-17 08:44:34
        [playertm] => 2014-01-17 08:44:38
    )

[5] => stdClass Object
    (
        [matchID] => 5
        [tm] => 2014-01-19 08:44:34
        [playertm] => 2014-01-19 08:44:38
    )
)

そして、時間に基づいて各アレイを同期しようとしています。4 つの結果が返されるようにします。

  1. 2 番目の配列より新しい時刻を持つ最初の配列のオブジェクト
  2. 最初の配列よりも新しい時刻を持つ 2 番目の配列内のオブジェクト
  3. 2 番目の配列より新しい「playertm」を持つ最初の配列のオブジェクト
  4. 最初の配列よりも新しい「playertm」を持つ 2 番目の配列内のオブジェクト

一部の結果は各配列にない場合があり、返される必要がありますが、配列キーは常に一致します。

私は「array_udiff」関数を使用していますが、これまでのところ次のとおりです。

function tmCompare($a, $b)
{
    return strtotime($a->tm) - strtotime($b->tm);
}
function ptmCompare($a, $b)
{
    return strtotime($a->playertm) - strtotime($b->playertm);
}

$df1 = array_udiff($a, $b, 'tmCompare');
$df2 = array_udiff($b, $a, 'tmCompare');

$df3 = array_udiff($a, $b, 'ptmCompare');
$df4 = array_udiff($b, $a, 'ptmCompare');

違いを返すように見えますが、配列 [4] は最後の 2 つの関数のそれぞれで返されますが、時間が異なるだけでなく大きい場合にのみ返されるようにします。

私が試してみました

return (strtotime($a->playertm) > strtotime($b->playertm)) ? -1 : 0;

と同様ですが、正しい結果が得られないようです。ここで何か簡単なことを見逃していますか、それともこれについて間違っていますか?

編集:コードを実行するための簡単なペーストビンは次のとおりですhttp://pastebin.com/gRz9v2kz

助けてくれてありがとう。

4

2 に答える 2

1

なぜこれが起こるのかはわかりませんが、 の使用はarray_udiff()直感に反しているようです。比較を実行し、配列を反復する 2 つの関数の要件を書き直しました。

function getCompareFunction($field)
{
        return function($a, $b) use ($field) {
                return strcmp($a->{$field}, $b->{$field});
        };
}

function getBigger($a, $b, $compare)
{
        $res = array();

        foreach ($a as $k => $v) {
                if (!isset($b[$k]) || $compare($v, $b[$k]) > 0) {
                        $res[$k] = $v;
                }
        }

        return $res;
}

$biggerTime = getCompareFunction('tm');
$biggerPlayerTime = getCompareFunction('playertm');

print_r(getBigger($a, $b, $biggerTime)); // [1, 2]
print_r(getBigger($b, $a, $biggerTime)); // [4, 5]
print_r(getBigger($a, $b, $biggerPlayerTime)); // [1, 2]
print_r(getBigger($b, $a, $biggerPlayerTime)); // [4, 5]
于 2014-01-20T14:58:03.183 に答える
0

次の構造で配列を再構築できれば簡単だと思います。したがって、2 つのオブジェクトから 4 つの組み合わせを作成できます。必要に応じて並べ替えることができます

[1] => stdClass Object
    (
        [matchID] => 1

        [tm] =>08:55:13
        [td] =>2014-01-16
        [playertm_date] => 2014-01-16
        [playertm_time] => 08:55:14

    )

もう1つの代替ソリューションはJsonです

于 2014-01-20T15:26:01.647 に答える