Удалить все между тегами php

Regex to remove an HTML tag and its content from PHP string

We use the in-built PHP strip_tags() function to remove HTML, XML, and PHP tags from a PHP string.

Example

Lorem Ipsum

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec nec volutpat ligula.

"; echo strip_tags($mystring);

Lorem IpsumLorem ipsum dolor sit amet, consectetur adipiscing elit. Donec nec volutpat ligula.

As you can see, it removes all the HTML tags and their attributes but retains all the content of those tags.

How to retain only specified tags

The strip_tags() function allows for a second optional argument for specifying allowable tags to be spared when the rest HTML tags get stripped off. This way, you can retain some and remove all the other tags.

Example

Lorem Ipsum

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec nec volutpat ligula.

"; echo strip_tags($mystring,"

,

");

Lorem Ipsum

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec nec volutpat ligula.

As you can see the rest of the tags have been removed leaving the string with only the and

, which were specified in the second argument.

How to remove certain tags with all their content

As opposed to the above examples where only tags are removed but their content remains intact, let’s see how we can do away with specific tags together with their content.

To achieve this we use the PHP preg_replace() function.

The first argument is the regular expression(we specify the tag(s) that we want to remove or replace in it), the second is the match(this is what we replace the specified tag(s) with) and the third is the string in which we want to make changes to.

Replace the terms «tag» with the respective opening and closing tags you wish to remove and $str with your string. These tags in the string will get replaced with whatever you set as the second argument, in this case, removed since we have used empty quotes «» .

Example

Lorem Ipsum

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec nec volutpat ligula.

"; echo preg_replace('~~Usi', "", $mystring);

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec nec volutpat ligula.

We have removed the tag and its content as specified in the function.

If you would like to strip off multiple tags with their content at a go, you can specify them as an array of regular expressions in the first argument of the function.

Example

Lorem Ipsum

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec nec volutpat ligula.

"; echo preg_replace(array('~~Usi','~~Usi','~~Usi'), "", $mystring);

Lorem sit amet, adipiscing elit. Donec nec volutpat ligula.

We have specified an array of , and , all which together with their content have been striped off.

That’s all for this article.

Источник

Как убрать текст между тегами в php?

Несмотря на использование PHP в течение многих лет, я никогда не научился использовать выражения для правильной усечения строк. которые теперь кусают меня сзади. Может ли кто-нибудь предоставить мне некоторую помощь, усекающую это? Мне нужно вырезать текстовую часть из URL-адреса, поворачивая

6 ответов

Хотя это работает, вы обычно не хотите анализировать HTML с регулярными выражениями. Ответ Карима может быть предпочтительнее.

find('a') as $e) < $e->innerText = null; > // dump contents echo $html; ?> 

Без обид, но этому ответу 8 лет, и никто на самом деле не заметил, что этот ответ неверен и не работает. Цикл foreach не имеет никакого эффекта при простом отображении $html . Не могу поверить, что это так много голосов, и никто на самом деле не проверял это.

Что-то вроде этого, учитывая, что вы захотите повторно использовать его с другим href :

$str = 'text'; $result = preg_replace('#(]*>).*?()#', '$1$2', $str); var_dump($result); 

(Я рассматриваю, что вы сделали опечатку в OP?)

Если вам не нужно сопоставлять другие href, вы можете использовать что-то вроде:

$str = 'text'; $result = preg_replace('#().*?()#', '$1$2', $str); var_dump($result); 

Которая также получит вас:

В качестве побочного элемента: для более сложного HTML не пытайтесь использовать регулярные выражения: они отлично подходят для такой простой ситуации, но для реальной части HTML-кода они действительно не помогают, в общем: HTML не довольно «регулярное» «достаточно» для анализа синтаксически регулярными выражениями.

Источник

strip_tags

Эта функция пытается возвратить строку str , из которой удалены все NULL-байты, HTML и PHP теги. Для удаления тегов используется тот же автомат, что и в функции fgetss() .

Список параметров

Второй необязательный параметр может быть использован для указания тегов, которые не нужно удалять.

Замечание:

Комментарии HTML и PHP-теги также будут удалены. Это жестко записано в коде и не может быть изменено с помощью параметра allowable_tags .

Замечание:

Этот параметр не должен содержать пробелов. strip_tags() рассматривает тег как нечувствительную к регистру строку, находящуюся между и первым пробелом или >.

Замечание:

В PHP 5.3.4 и новее также необходимо добавлять соответвующий закрывающий тег XHTML, чтобы удалить тег из str . Например, для удаления и и
нужно сделать следующее:

Возвращаемые значения

Возвращает строку без тегов.

Список изменений

Версия Описание
5.3.4 strip_tags() больше не удаляет соответвующие закрывающие XHTML теги, если они не переданы в allowable_tags .
5.0.0 strip_tags() теперь безопасна для обработки бинарных данных.

Примеры

Пример #1 Пример использования strip_tags()

Результат выполнения данного примера:

Примечания

Из-за того, что strip_tags() не проверяет валидность HTML, то частичные или сломанные теги могут послужить удалением большего количества текста или данных, чем ожидалось.

Эта функция не изменяет атрибуты тегов, разрешенных с помощью allowable_tags , включая такие атрибуты как style и onmouseover, которые могут быть использованы озорными пользователями при посылке текста, отображаемого также и другим пользователям.

Замечание:

Имена тегов в HTML превышающие 1023 байта будут рассматриваться как невалидные независимо от параметра allowable_tags .

Смотрите также

Источник

Как удалить текст между тегами в php?

Несмотря на использование PHP в течение многих лет, я никогда не научился использовать выражения для правильной усечения строк …, которые теперь кусают меня сзади!

Может ли кто-нибудь предоставить мне некоторую помощь, усекающую это? Мне нужно вырезать текстовую часть из URL-адреса, поворачивая

find('a') as $e) < $e->innerText = null; > // dump contents echo $html; ?> в find('a') as $e) < $e->innerText = null; > // dump contents echo $html; ?> 

Что-то вроде этого, учитывая, что вы захотите повторно использовать его с другими href s:

$str = 'text'; $result = preg_replace('#(]*>).*?()#', '$1$2', $str); var_dump($result); 

(Я рассматриваю, что вы сделали опечатку в OP?)

Если вам не нужно сопоставлять другие href, вы можете использовать что-то вроде:

$str = 'text'; $result = preg_replace('#().*?()#', '$1$2', $str); var_dump($result); 

Который также получит вас:

В качестве побочного элемента: для более сложного HTML не пытайтесь использовать регулярные выражения: они отлично подходят для такой простой ситуации, но для реальной части HTML-кода они действительно не помогают, в общем: HTML не довольно «регулярный» «достаточно», чтобы анализировать регулярные выражения.

Используйте только strip_tags() , которые избавятся от тегов и оставят только желаемый текст между ними

Вы можете использовать подстроку в сочетании со строками, хотя это не очень хороший подход.

Проверить: PHP Manual – Строковые функции

Другой способ – написать регулярное выражение, соответствующее вашим критериям. Но чтобы быстро решить вашу проблему, строковые функции будут …

EDIT: Я недооценил аудиторию. 😉 Продолжайте с регулярными выражениями … ^^

Вам не нужно захватывать сами теги. Просто настройте текст между тегами и замените его пустой строкой. Супер простой.

Это позволяет избежать затрат на группы захвата, используя ленивый квантификатор, перезапуск fullstring \K и «lookahead».

Источник

Читайте также:  Javascript one page back
Оцените статью