Использование implode для группировки информации из полученного в цикле while
-
08-07-2019 - |
Вопрос
У меня возникла следующая проблема. У меня есть номера 1/2/3/4/5/6, и я хочу разделить их на две группы 1/3/5 и 2/4/6. Выбор должен осуществляться на основе позиции. Эта часть работает нормально. Проблема возникает, когда я хочу снова сгруппировать их, когда я использую функцию выгрузки; он видит только последний номер, который был сохранен. Я знаю, что это как-то связано со мной, используя эту нотацию (я выбрал этот способ, поскольку количество чисел, которые нужно классифицировать, меняется каждый раз):
$q++;
$row0 = $row0 + 2;
$row1 = $row1 + 2;
но я не могу найти способ исправить это или другой способ получить тот же результат. Надеюсь, кто-то здесь может указать мне правильное направление. Я оставил полный код ниже.
<Ч><?
$string = "1/2/3/4/5/6";
$splitted = explode("/",$string);
$cnt = count($splitted);
$q=0;
$row0=0;
$row1=1;
while($cnt > 2*$q)
{
$p_row = implode(array($splitted[$row0]));
echo "$p_row <br>";
$i_row = implode(array($splitted[$row1]));
echo "$i_row <br>";
$q++;
$row0 = $row0 + 2;
$row1 = $row1 + 2;
}
$out = "implode(',', $i_row)";
var_dump($out);
?>
<Ч> Решение
Вы можете разбить массив на группы, используя %
по индексу цикла. Поместите каждую группу в отдельный массив. Вот пример:
<?php
$string = "1/2/3/4/5/6";
$splitted = explode("/",$string);
$group_odd = array(); ## all odd elements of $splitted come here
$group_even = array(); ## all even elements of $splitted come here
for ($index = 0; $index < count($splitted); ++$index) {
## if number is divided by 2 with rest then it's odd
## but we've started calculation from 0, so we need to add 1
if (($index+1) % 2) {
$group_odd[] = $splitted[$index];
}
else {
$group_even[] = $splitted[$index];
}
}
echo implode('/', $group_odd), "<br />"; ## outputs "1/3/5<br />"
echo implode('/', $group_even), "<br />"; ## outputs "2/4/6<br />"
print_r($group_odd);
print_r($group_even);
?>
Другие советы
Кажется, я неправильно прочитал проблему. Вместо этого я даю эту оптимизацию.
$string = "1/2/3/4/5/6";
$splitted = explode("/", $string);
$group = array();
for ($index = 0, $t = count($splitted); $index < $t; ++$index) {
$group[$index & 1][] = $splitted[$index];
}
$oddIndex = $group[0]; //start with index 1
$evenIndex = $group[1]; //start with index 2
echo "odd index: "
. implode('/', $oddIndex)
. "\neven index: "
. implode('/', $evenIndex)
. "\n";
На основании их позиции? Итак, разделить на основе четности / нечетности их индекса в массиве?
Примерно так?
<?php
$string = "1/2/3/4/5/6";
list( $evenKeys, $oddKeys ) = array_split_custom( explode( '/', $string ) );
echo '<pre>';
print_r( $evenKeys );
print_r( $oddKeys );
function array_split_custom( array $input )
{
$evens = array();
$odds = array();
foreach ( $input as $index => $value )
{
if ( $index & 1 )
{
$odds[] = $value;
} else {
$evens[] = $value;
}
}
return array( $evens, $odds );
}