如果多维数组中的值取消整个包含的数组

时间:2013-03-04 11:09:52

标签: php search multidimensional-array unset array-multisort

我有一个脚本可以将项目添加到数据库。

目前我有一个像这样创建的数组:

foreach(blah as $album){

$add[] = array('album' => $album['name'],
               'test' => $album['test']
            );

} // end foreach

相册名称并不总是唯一的,$album['test']可以是随机文本(稍后使用),也可以是“FALSE' (当我说错时,我的意思是,这个词是假的,用文字拼写)

我需要一个函数以某种方式搜索数组,并比较名称和测试值...每个专辑名称可能有几个条目,有几个不同的随机文本值,一个说FALSE。如果有一个数组条目,测试值设置为FALSE,那么它将删除所有其他包含相同专辑名称的数组...

所以这个:

array(array('album' => 'album_name1', 'test' => 'xqus8n4n'),
      array('album' => 'album_name1', 'test' => 'FALSE'),
      array('album' => 'album_name1', 'test' => 'jdh4dhdk'),
      array('album' => 'album_name2', 'test' => 'hdis8ebk'),
      array('album' => 'album_name2', 'test' => 'hisb8bs7'),
      array('album' => 'album_name2', 'test' => 'FALSE'),
      array('album' => 'album_name3', 'test' => 'yek98abk'),
      array('album' => 'album_name3', 'test' => '8iksh2q7')
     );

成为这个:

array(array('album' => 'album_name1', 'test' => 'FALSE'),
      array('album' => 'album_name2', 'test' => 'FALSE'),
      array('album' => 'album_name3', 'test' => 'yek98abk'),
      array('album' => 'album_name3', 'test' => '8iksh2q7')
     );

我希望这是有道理的,因为除非你知道我的整个脚本结构,否则看起来有点混乱,这就是为什么我提供了这么多信息。

3 个答案:

答案 0 :(得分:1)

$multiarray = array(
      array('album' => 'album_name1', 'test' => 'xqus8n4n'),
      array('album' => 'album_name1', 'test' => 'FALSE'),
      array('album' => 'album_name1', 'test' => 'jdh4dhdk'),
      array('album' => 'album_name2', 'test' => 'hdis8ebk'),
      array('album' => 'album_name2', 'test' => 'hisb8bs7'),
      array('album' => 'album_name2', 'test' => 'FALSE'),
      array('album' => 'album_name3', 'test' => 'yek98abk'),
      array('album' => 'album_name3', 'test' => '8iksh2q7')
     );

$keysToRemove = array( );

// Go and find all the FALSE values and which albums they belong to
foreach ( $multiarray as $album ) {
  if ( in_array( 'FALSE', $album ) ) {
    $keysToRemove[] = $album['album'];
  }
}

// Remove all instances of the albums that had FALSE values
// except the ones that had the word FALSE (we keep those :p )
for( $i = 0; $i < count($multiarray); $i++ ) {
    if ( ( in_array( $multiarray[$i]['album'], $keysToRemove ) ) && ( $multiarray[$i]['test'] != 'FALSE' ) ){
        unset( $multiarray[$i] );
    }
}

// reset keys so that they are numerical again.
$multiarray = array_values(array_filter($multiarray)); 

print_r( $multiarray );

给出以下结果:

Array ( 
  [0] => Array ( [album] => album_name1 [test] => FALSE ) 
  [1] => Array ( [album] => album_name2 [test] => FALSE ) 
  [2] => Array ( [album] => album_name3 [test] => yek98abk ) 
  [3] => Array ( [album] => album_name3 [test] => 8iksh2q7 ) 
) 

答案 1 :(得分:0)

使用php函数array_key_exists()

foreach($album as $alb){

 if (array_key_exists('FALSE', $alb)) {

  // Remove other array keys or save into new array
 }

} // end foreach

答案 2 :(得分:0)

这给出了你想要的输出

  function array_searches($item,$key,$keys,$value){
    if($key[$keys]==$value){
    return true;
    }
    return false;
    }
    $array= array(
          array('album' => 'album_name1', 'test' => 'xqus8n4n'),
          array('album' => 'album_name1', 'test' => 'FALSE'),
          array('album' => 'album_name1', 'test' => 'jdh4dhdk'),
          array('album' => 'album_name2', 'test' => 'hdis8ebk'),
          array('album' => 'album_name2', 'test' => 'hisb8bs7'),
          array('album' => 'album_name2', 'test' => 'FALSE'),
          array('album' => 'album_name3', 'test' => 'FALdsfSE'),
        array('album' => 'album_name3', 'test' => 'FALsdfSE'),
    );

    $i=0;


function custom_op($array){
$new_array=array();
foreach ($array as $key=>$value){
if(array_custom_search($key,$value,'test','FALSE')){
$new_array[]=$value;
foreach($array as $key1=>$value1){
if(array_search($key1,$value1,'album',$value['album'])){
unset($array[$key1]);//unset the array value where 'test' is false 
}
}
}
}


foreach ($new_array as $key=> $value){
$array[]=$value;
}
echo "<pre>asdf";
print_r($array);
}