(データベースなどから取得した)多次元配列の値と、一次元配列を比較して、「一致」及び「増減」を返す

配列

 閲覧数:1219  投稿日:2020-02-18  更新日:2020-02-26  

存在している値を比較する
・等しい … trueを返す
・減少
・増加


※キーは関係ない


-----------------------------------
返ってきた後
空の配列をforeachすると、

<?php
foreach(array() as $a) {
print_r('hoge' . PHP_EOL);
}
エラー出力されない。何も出力されない


コード

<?php
function diff($data,$post)
{
    $pickAry = array_column($data,"tag_id","id");//DB取得データよりarray(id => tag_id)を抽出
    var_export($pickAry);

    $del = array_diff($pickAry,$post);
    $ins = array_diff($post,$pickAry);

    //if(!empty($del)) $del = array_keys($del); //キーを値として取得したい場合に使用。キーは新たに振り直される
    //if(!empty($ins)) $ins = array_values($ins); //(値を値として取得したい場合に使用。)キーが新たに振り直される
    
    if(empty($del)&&empty($ins)) return TRUE;
    //
    return array($del,$ins);
}
//存在している値は等しい、キーは関係ない
$dbAry = [
  [ 'id' => '2',
    'entry_id' => '1',
    'tag_id' => '3',
  ],
  [ 'id' => '1',
    'entry_id' => '1',
    'tag_id' => '2',
  ],
];
$postAry = [
  0 => '3',
  1 => '2',
];
var_export(diff($dbAry,$postAry));


//存在している値の増減を返す。キーは関係ない
$dbAry = [
  [ 'id' => '2',
    'entry_id' => '1',
    'tag_id' => '3',
  ],
  [ 'id' => '1',
    'entry_id' => '1',
    'tag_id' => '2',
  ],
];
$postAry = [
  8 => '2',
  7 => '9',
];
var_export(diff($dbAry,$postAry));



結果

//存在している値は等しい、キーは関係ない
array (
  2 => '3',
  1 => '2',
)
//一致
true


//存在している値の増減を返す。キーは関係ない
array (
  2 => '3',
  1 => '2',
)
//[0]減少分,[1]増加分
array (
  0 => 
  array (
    2 => '3',
  ),
  1 => 
  array (
    7 => '9',
  ),
)



タグ


array_column 





array_diffを使用して、「複数配列」間で「存在している値」を比較後、その結果を配列で返す

配列キー内に「指定文字列が含まれるキー」と「その値」を抽出して、新しい配列を返す



類似度ページランキング
順位 ページタイトル抜粋
1 (データベースなどから取得した)多次元配列の値と、一次元配列を比較して、「一致」及び「増減」を返す 78
2 (データベースなどから取得した)多次元配列の構造を変換して一次元配列を返す 60
3 多次元配列で「一次元目の最大値 +1 」 を返す 36
4 多次元配列で「二次元目の最大値 +1 」 を返す 33
5 配列のキーと値を反転した新しい配列を返す array_flip() 32
6 UNIXのタイムスタンプから日付(文字列)を取得後、「アクセスした時点の年月日時分秒」を整形して表示 … date() 31
7 配列キー内に「指定文字列が含まれるキー」と「その値」を抽出して、新しい配列を返す 31
8 文字列としてフォーマットされた配列値を返す 31
9 多次元配列キーを、多次元配列内にある「特定キーの値」へ変更 31
10 日付(文字列)から、指定時刻のUNIXタイムスタンプを取得 31
11 配列の中より、「ランダム」かつ「重複することなく」複数の値を抽出 30
12 多次元配列で「二次元目にある指定値のカウント数 +1 」 を返す 30
13 連想配列を(キーと値の関係性を維持したまま)シャッフル 29
14 array_diffを使用して、「複数配列」間で「存在している値」を比較後、その結果を配列で返す 29
15 現在のセッションクッキーのパラメータ情報を配列として返す 29
16 「二次元目の指定キーが指定値である、二次元目配列」を削除 29
17 配列のキーを取得する array_keys() 28
18 UNIXのタイムスタンプから日付(文字列)を取得後、「現在の年月日時分秒」を表示 … getdate() 28
19 多次元配列の「一次元要素数」もしくは「全次元要素数」をカウント 28
20 要素のキーと初期値を指定して配列を作成する array_fill_keys() 27
2024/11/23 10:55 更新
週間人気ページランキング / 11-16 → 11-22
順位 ページタイトル抜粋 アクセス数
1 配列キー内に「指定文字列が含まれるキー」と「その値」を抽出して、新しい配列を返す | 配列(型) 8
1 後ろから3文字削除 / 「18:00:00」→「18:00」 | 文字列(テキスト処理) 8
2 URLから、トップページ(index.html)判定 | ルーティング 6
3 指定文字列より前を取得 | 文字列(テキスト処理) 5
4 配列の内容(ひらがな)を、読み(あ行~わ行)で分け、新たな配列へ格納 | 配列(型) 4
4 MySQLのdatetime型カラムに格納している値と比較して、24時間以内かどうかを判定 | 日付および時刻関連 4
5 現在WebページのURLパスを第2階層まで取得 | パス 3
5 対象文字列の内、「最初の指定文字列以前」と「それ以降の文字列」を取得する | 文字列(テキスト処理) 3
5 2 つの配列(文字列とdatetime)が要素順で 対応している時、日付を整形して 新しい配列を作成 | 配列(型) 3
6 再帰処理で平坦な連想配列をツリー化 | 多次元配列(型) 2
6 「1週間後の年月日時分秒」を表示 … time() | 日付および時刻関連 2
6 投稿日時をTwitterのように「★分前」「★時間前」という文字列変換するユーザ定義PHP関数 | 日付および時刻関連 2
6 配列要素を、文字列連結して表示(元配列を上書) … foreach文+implode | 配列(型) 2
6 8桁の生年月日数字から、年齢を計算 | 日付および時刻関連 2
6 null代入とunset()の違い | 変数 2
6 PHPで最後の「指定区切り文字」より後ろを取得 | 配列(型) 2
7 配列定数同士をarray_mergeで後ろに単純連結(キーは新たに振り直す) | 定数 1
7 gethostbyaddr / IPアドレスからホスト名を取得 | ネットワーク 関数 1
7 マークダウンで書かれたURLを(エスケープ処理するのではなく)削除する | テキスト処理 1
7 対象文字列を、文字数に応じて半分に分割後、それぞれを取得 | 文字列(テキスト処理) 1
2024/11/23 1:02 更新