2

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

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

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')
     );

我希望这是有道理的,因为除非你知道我的整个脚本结构,否则它看起来有点令人困惑,这就是我提供这么多信息的原因。

4

3 回答 3

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 ) 
) 
于 2013-03-04T11:30:46.710 回答
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
于 2013-03-04T11:22:12.850 回答
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);
}
于 2013-03-04T12:25:48.617 回答