3

我一直试图在array_unique没有成功的情况下内爆 2 个变量。2 个变量进行 mysql 调用,每个都返回 data ok。放在一个数组中也会返回两者的数据,但是,当它们内爆时,array_unique它们有重复的数据,我希望在返回时清理这些数据。建议将不胜感激。

$a = 'mysql string 1';// basically words A, B, C
$b = 'mysql string 2';// basically words D, A, E
$a_b_array = array($a, $b);
sort($a_b_array);
$a_b_string = implode("\n", array_unique($a_b_array));

echo $a_b_string; //returns $a and $b with duplicated data

我也试过SORT_REGULAR了,不要认为这是问题:

//sort($a_b_array);
$a_b_string = implode("\n", array_unique($a_b_array, SORT_REGULAR);

预期结果是:A、B、C、D、E

4

2 回答 2

5

首先,您正在处理一个包含两个元素的数组。您需要先将每个元素分解为数组。

<?php
// define your inputs    
$a = 'A, B, C';
$b = 'D, A, E';

// explode the string into arrays and merge them
$a_b_array = array_merge(explode(",", $a), explode(",", $b));

// trim off any pesky leading or trailing spaces from the elements
$a_b_array = array_map("trim", $a_b_array);

sort($a_b_array);
// tape the elements back together separated by a newline
$a_b_string = implode("\n", array_unique($a_b_array));
echo $a_b_string; 
于 2014-01-05T03:58:39.410 回答
1
$a = 'mysql string 1'; // basically words A, B, C
$b = 'mysql string 2'; // basically words D, A, E

$a_explode = explode(" ", $a);
$b_explode = explode(" ", $b);

$a_b_array =  array_unique(array_merge($a_explode, $b_explode));
sort($a_b_array);
var_dump($a_b_array);
echo implode(", ", $a_b_array);

输出 :

array (size=4)
  0 => string '1' (length=1)
  1 => string '2' (length=1)
  2 => string 'mysql' (length=5)
  3 => string 'string' (length=6)
1, 2, mysql, string
于 2014-01-05T04:06:11.303 回答