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

Форум PHP

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

 

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

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

тема: вырезать строки из таблицы
 
 автор: D13   (24.05.2007 в 15:50)   письмо автору
 
 

покажите пож-та как вырзать строку
таблица состоит из двух строк по три стобца

| aa | bb | + |
| cc | dd | |

как вырезать полностью строку где присутсвует плюс
чтоб остались только строки где плюс отсутствует

спасибо.

   
 
 автор: coloboc66   (24.05.2007 в 17:07)   письмо автору
 
   для: D13   (24.05.2007 в 15:50)
 

Можно с помощью DOM и JavaScript

   
 
 автор: cheops (из кафе)   (24.05.2007 в 17:46)
 
   для: D13   (24.05.2007 в 15:50)
 

Таблица HTML или MySQL?
Вырезать - это удалить или извлечь в отдельный массив?

   
 
 автор: D13   (25.05.2007 в 05:18)   письмо автору
 
   для: cheops (из кафе)   (24.05.2007 в 17:46)
 

прошу прощения за неточность, сейчас поясню

имеется в виду обычная html таблица.
Задача которую не могу решить получилась таким образом
был написан парсер вырезавший с сайта поставщика все кроме таблицы с ценами на товар и отметкой знаком "+" есть товар в наличии или нет.
все вырезал а вот элементарно вырезать из html таблицы строки не содержащие "+" не могу.

Подскажите пож-та.

спасибо

   
 
 автор: kasmanaft   (25.05.2007 в 06:21)   письмо автору
 
   для: D13   (25.05.2007 в 05:18)
 

Приведите свою таблицу, нужно точно знать где этот плюс стоит.
Вот приблизительный код

<?php
$text 
"<tr><td>a</td><td>+</td></tr>
<tr><td>a</td><td>не_плюс:)</td></tr>"
;
echo 
preg_replace("#<tr>((?!(\+|</tr>)).)*</tr>#"""$text);
?>

Используя это рег. останутся все строки, в которых встретится хотя бы один "+" - в любом месте между <tr> и </tr>. Если "+" стоит между <td> </td> (или еще что-нить рядом стоит, что повторяется во всех случаях), попробуйте добавить их в рег. выражение рядом (вместо?) с плюсом.

   
 
 автор: D13   (25.05.2007 в 11:19)   письмо автору
 
   для: kasmanaft   (25.05.2007 в 06:21)
 

вот такая таблица

<table width=500 border=1 cellspacing=0 cellpadding=0>
<tr>
<td width=635 >стол</td>
<td width=150 align=center>1 580</td>
<td align=center>+ &nbsp;</td>
</tr>
<tr>
<td width=635 >стул</td>
<td width=150 align=center>1 580</td>
<td align=center> &nbsp;</td>
</tr>
</table>

   
 
 автор: kasmanaft   (25.05.2007 в 11:42)   письмо автору
 
   для: D13   (25.05.2007 в 11:19)
 

Тогда можно что-то вроде этого использовать:

"#<tr>((?!(>\+ &nbsp;</td>|</tr>)).)*</tr>#si"

   
 
 автор: Trianon   (25.05.2007 в 12:03)   письмо автору
 
   для: D13   (25.05.2007 в 11:19)
 

такие строки наверное можно за один раз preg_match_all отпарсить. Вместе с содержимым и с плюсом...

<?php

  $pattern 
'|<tr>[\s]*<td[^>]+>([^<]*)</td>[\s]*<td[^>]+>([^<]*)</td>[\s]*<td[^>]+>([+]?)([^<]*)</td>[\s]*</tr>|';
  
$text '
  <table width=500 border=1 cellspacing=0 cellpadding=0>
<tr>
<td width=635 >стол</td>
<td width=150 align=center>1 580</td>
<td align=center>+ &nbsp;</td>
</tr>
<tr>
<td width=635 >стул</td>
<td width=150 align=center>1 580</td>
<td align=center> &nbsp;</td>
</tr>
</table>'
;
 echo   
preg_match_all($pattern$text$outPREG_SET_ORDER);
 echo 
'<pre>';
 
print_r($out);
?>

   
Rambler's Top100
вверх

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