Форум: Форум PHPФорум ApacheФорум Регулярные ВыраженияФорум MySQLHTML+CSS+JavaScriptФорум FlashРазное
Новые темы: 0000000
Самоучитель PHP 5 / 6 (3 издание). Авторы: Кузнецов М.В., Симдянов И.В. Программирование. Ступени успешной карьеры. Авторы: Кузнецов М.В., Симдянов И.В. PHP 5. На примерах. Авторы: Кузнецов М.В., Симдянов И.В., Голышев С.В. Социальная инженерия и социальные хакеры. Авторы: Кузнецов М.В., Симдянов И.В. MySQL на примерах. Авторы: Кузнецов М.В., Симдянов И.В.
ВСЕ НАШИ КНИГИ
Консультационный центр SoftTime

Форум PHP

Выбрать другой форум

 

Здравствуйте, Посетитель!

вид форума:
Линейный форум Структурный форум

тема: чет и нечет!!
 
 автор: shmelnikov   (31.07.2007 в 18:53)   письмо автору
 
 

я начинающий программист.... есть вопрос
можно ли как-нибудь выбрать из результативного массива mysql_num_rows() нечетные элементы?

   
 
 автор: Trianon   (31.07.2007 в 19:08)   письмо автору
 
   для: shmelnikov   (31.07.2007 в 18:53)
 

mysql_num_rows() - это не массив, а число.
нечетные строки можно отметить флажком $flop ^= 1;

   
 
 автор: shmelnikov   (31.07.2007 в 19:16)   письмо автору
 
   для: Trianon   (31.07.2007 в 19:08)
 

Спасибо за замечание,а вот только не понял... флажок что используется в качестве аргумента в скобках или в качестве переменной которая сравнивается числом mysql_num_rows()...
Просто пока не догоняю извините...

   
 
 автор: cheops   (01.08.2007 в 12:29)   письмо автору
 
   для: shmelnikov   (31.07.2007 в 19:16)
 

Нет, его следует ввести в цикл обработки функции mysql_fetch_array()
<?php
  
if(mysql_num_rows($row))
  {
    
$flop 1;
    while(
$table mysql_fetch_array($row))
    {
      if(
$flop)
      {
         
$arr[] = $table['field'];
         
$flop 0;
      }
      else 
$flop 1;
    }
  }
?>

   
 
 автор: Trianon   (01.08.2007 в 12:42)   письмо автору
 
   для: cheops   (01.08.2007 в 12:29)
 

Я бы набросал такой пример
<table><?php 
  $bgcolors
[] = "#FFFFFF";   $bgcolors[] = "#CCCCCC";
  
$res mysql_query("SELECT name FROM tbl");
  
$flop 1
  while(
$row mysql_fetch_assoc($res)) 
  { 
      
$bg $bgcolors[$flop ^= 1];
      echo 
"<tr><td bgcolor=$bg >Text: $row[text] </td></tr>";
  } 
?></table> 

   
 
 автор: cheops   (01.08.2007 в 12:55)   письмо автору
 
   для: Trianon   (01.08.2007 в 12:42)
 

Хм... я так понял чётные строки вообще не требуется выводить? или они всё-таки нужны?

   
 
 автор: Trianon   (01.08.2007 в 12:59)   письмо автору
 
   для: cheops   (01.08.2007 в 12:55)
 

Да нет... Вы формально правы...
Это я не могу придумать практического примера, когда именно четные (или именно нечетные) строки вообще потребовалось бы выкинуть из отчета.

   
 
 автор: amigo62   (01.08.2007 в 14:22)   письмо автору
 
   для: Trianon   (01.08.2007 в 12:59)
 

А что происходит с $flop в процессе цикла? Я так понимаю, вместо индекса оказывается поочередно то 1, то 0 , а каким образом не понимаю )

   
 
 автор: Trianon   (01.08.2007 в 15:46)   письмо автору
 
   для: amigo62   (01.08.2007 в 14:22)
 

$flop ^= 1 эта операция изменяет младший разряд числа, лежащего в переменной $flop.

   
 
 автор: shmelnikov   (05.08.2007 в 01:40)   письмо автору
 
   для: cheops   (01.08.2007 в 12:29)
 

Cпасибо большое.... я примерно так и сделал... )))) нашел подходящий пример )))
но все равно вам спасибо за внимание .. и помощь

   
Rambler's Top100
вверх

Rambler's Top100 Яндекс.Метрика Яндекс цитирования