Использование implode для группировки информации из полученного в цикле while

StackOverflow https://stackoverflow.com/questions/1640617

  •  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 );
}
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top