0

私は多次元配列を持っています:

array (
    array (
        "username"        => "foo",
        "favoriteGame"    => "Mario"
    )
    array (
        "username"        => "bar",
        "favoriteGame"    => "Mario"
    )
    array (
        "username"        => "xyz",
        "favoriteGame"    => "Zelda"
    )
)

たとえばマリオをできるだけ簡単にプレイしたい人のユーザー名を取得するにはどうすればよいですか?

編集: 私のせい:「favoriteGame」の値は動的であり、それがどれであるかを事前に知ることができないことを明示的に言及するのを忘れてください。

私の解決策:

foreach($users as $key => $value)
{
    if(!isset($$value['favoriteGame']))
    {
        $$value['favoriteGame'] = array();
    }
    array_push($$value['favoriteGame'], $value['username']);
}

各サブ配列を繰り返し処理して、favoriteGameの値を見つけます。配列$favoriteGameがまだない場合は、それを作成します。実際のサブ配列のusername-valueを$favoriteGame配列にプッシュします。

返信ありがとうございます。この質問を正しく表現できませんでした。

4

7 に答える 7

6
function getUsernamesByFavoriteGame($data, $game) {
    $usernames = array();
    foreach($data as $arr) {
        if ($arr['favoriteGame'] == $game) {
            $usernames[] = $arr['username'];
        }
    }
    return $usernames;
}
于 2012-05-30T07:38:03.263 に答える
5
 $usernames = array();
 foreach($array as $key => $value) {
     if ($value['favoriteGame'] == 'Mario') {
         $usernames[] = $value['username'];
     }
 }
于 2012-05-30T07:38:31.623 に答える
4

私は使用しますarray_filter。PHP 5.3以降を使用している場合は、次のように実行できます。

$favorite = "Mario";
$filter = function($player) use($favorite) { return $player['favoriteGame'] == $favorite; };
$filtered = array_filter($players, $filter);

ラムダ関数を使用できないため、古いバージョンでは少し異なります。

于 2012-05-30T07:45:07.583 に答える
2
 $game = 'Mario';   
 $users = array();
 foreach($array as $key => $value) {
     if ($value['favoriteGame'] == $game) {
         $users[] = $value['username'];
     }
 }
于 2012-05-30T07:44:01.963 に答える
2

これをより頻繁に使用する場合は、データ構造を次のようなものに変換してください。

 array(
   "Mario" => array(
               "0":"foo",
               "1":"xyz"
               )
   "Zelda" => array(
               "0":"pqr",
               "1":"abc"
              )
 )

これにより、お気に入りのゲームのユーザー名のリストが直接表示されます。

$arr[$favGame]

データ構造を変更できない場合は、tigrangを使用してください。

于 2012-05-30T07:44:08.697 に答える
1

カスタム多次元検索機能を実装する必要があると思います。この答え
を見てください。


使い方は次のとおりです

コード| 実例

function search($array, $key, $value){
    $results = array();

    if (is_array($array))
    {
        if (isset($array[$key]) && $array[$key] == $value)
            $results[] = $array;

        foreach ($array as $subarray)
            $results = array_merge($results, search($subarray, $key, $value));
    }

    return $results;
}

$arr = array (
    array (
        "username"        => "foo",
        "favoriteGame"    => "Mario"
    ),
    array (
        "username"        => "bar",
        "favoriteGame"    => "Mario"
    ),
    array (
        "username"        => "xyz",
        "favoriteGame"    => "Zelda"
    )
);

print_r(search($arr, 'favoriteGame', 'Mario'));

//OUTPUT
Array ( 
    [0] => Array ( 
        [username] => foo 
        [favoriteGame] => Mario 
    ) 
    [1] => Array ( 
        [username] => bar 
        [favoriteGame] => Mario 
    ) 
) 
于 2012-05-30T08:02:06.483 に答える
0
$array = array( 'a' => 'A',
    'b'=>'B',
    'c'=>'C',
    'd'=>array(
        'e'=>array(
           'f'=>'D'
        ),
        'g'=>array(
            'h'=>'E'
        )
    ),
    'i'=>'F',
    'j'=>array(
        'k'=>'G'
    ),
    'l'=>'H'
);

$new_array = array();
foreach($array as $k1=>$v1){
    if(is_array($v1)){
        $new_array = parseArray($new_array, $k1, $v1);
    }else{
        $new_array = array_merge($new_array, array($k1=>$v1));
    }
}

function parseArray($new_array, $key, $val){
    if(is_array($val)){
        foreach($val as $k2=>$v2){
            if(is_array($v2)){
               $new_array = parseArray($new_array, $k2, $v2);
            }else{
               $new_array = array_merge($new_array, array($k2=>$v2));
            }
        }
    }else{
        $new_array = array_merge($new_array, array($key=>$val));
    }
    return $new_array;
}

出力

Array
(
    [a] => A
    [b] => B
    [c] => C
    [f] => D
    [h] => E
    [i] => F
    [k] => G
    [l] => H
)
于 2014-07-12T14:04:43.543 に答える