В связи с переходом на новый движок... возможны сбои в работе! Простите!
Работы производятся прямо сейчас 19-03-2024! 🞨
Меню :
php (329)
search (5)



Blog (1392)
php (329)
js (244)
html (147)
css (131)
html tags (62)
js tag (56)
jquery (42)
text (37)
js method (36)
php array (33)
js date (33)
form html (30)
online (29)
Показать еще :
fonts (26)
ruweb.net (25)
foto (22)
php file (20)
atom (20)
forum (19)
hosting (18)
svg (18)
input (18)
php date (17)
board (16)
php time (16)
html book (16)
color (15)
info (15)
img (14)
js time (14)
js url (14)
js events (14)
htaccess (13)
select (13)
notepad (13)
osclass (13)
keyboard (12)
знак (12)
dw block (12)
php img (12)
php path (12)
table (12)
download (12)
icon (11)
form (11)
jsphp (11)
alphabet (10)
keyframes (10)
js delete (10)
yandex (10)
mouse (10)
chart (9)
hover (9)
dosite (8)
browser (8)
php post (7)
comment (7)
php url (7)
iframe (6)
php get (6)
mysql (6)
click (6)
list (6)
canvas (6)
adminka (6)
vs code (6)
js id (5)
mb (5)
heading (5)
value (5)
reg.ru (5)
ftp (5)
year (5)
js math (5)
tag a (5)
bbcode (4)
php var (4)
base64 (4)
xml (4)
scandir (4)
games (4)
flags (4)
symbols (4)
week (4)
day (4)
ssl (4)
нок (4)
submit (4)
task (4)
vk (4)
month (4)
pages (4)
console (4)
js form (4)
domen (3)
line (3)
https (3)
js post (3)
jquery post (3)
money (3)
numbers (3)
js img (3)
padding (3)
куб (3)
captcha (3)
ucoz (3)
js hash (3)
tag hr (2)
details (2)
typeof (2)
seo (2)
prompt (2)
sitemap (2)
рся (2)
youtube (2)
height (2)
arrows (2)
js vars (2)
counter (2)
google (2)
qr kod (2)
video (2)
speed (1)
smile (1)
нод (1)
rutube (1)
scroll (1)
windows (1)
archive (1)
jino (1)
cursor (1)

Как найти строку, которую невозможно найти?

"Сложный поиск строки" - изложение решения задачки...

Давно работающий скрипт - установка дополнительной строки(значение переменное), до или после найденной строки... - перестал работать

Пример решения задачки Сложный поиск строки

  1. Сложный поиск строки - вариант №1
  2. Сложный поиск строки - вариант №2

  1. Сложный поиск строки - описание...

    Далее в коде... постоянное, только атрибуты классов, остальные значения + html - это переменные! Которые меняются в зависимости от страницы!

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

    <ol class="count_levels">

      <li><a href="#paragraph_1">заголовок</a></li>

      <li><a href="#paragraph_2">заголовок</a></li>

    Сюда требуется добавить

    </ol>

    <ol class="count">

      <a name="paragraph_1"></a><li></li>

      <h2>Заголовок</h2>

      <a name="paragraph_2"></a><li></li>

      <h2>Заголовок</h2>

    Для представленого кода есть простое решение!

    Решение - нахождение и замена:

    Мы можем воспользоваться preg_match_all. Получаем все, что есть между

    class="count_levels">

    И следующим тегом

    </ol>

    В выражении будет так:

    preg_match_all('#class="count_levels">(.+?)</ol>#is', $example, $arr);

    Далее заменяем полученную ячейку

    $arr[1][0]

    На такую же, но только с добавленным содержанием:

    $arr[1][0]."\n Добавляемый элемент"

    И выводим с помощью echo

    Код в сборе:

    $example = '<ol class="count_levels">

      <li><a href="#paragraph_1">заголовок</a></li>

      <li><a href="#paragraph_2">заголовок</a></li>

    </ol>

    <ol class="count">

      <a name="paragraph_1"></a><li></li>

      <h2>Заголовок</h2>

      <a name="paragraph_2"></a><li></li>

      <h2>Заголовок</h2>';

    preg_match_all('#class="count_levels">(.+?)</ol>#is', $example, $arr);

    echo str_replace($arr[1][0] , $arr[1][0]."\n Добавляемый элемент" , $example);

    посмотреть результат...

  2. Сложный поиск строки - вариант №2

    Но далее... если html усложняется... в виде вложенного "<ol>" - то выше приведенный вариант перестает работать - посмотреть результат... и вообще все другие варианты, которые я знаю...

    Как решить?

    $example = '

    <ol class="count_levels">

        <li><a href="#paragraph_1">заголовок</a>

          <ol class="count_levels">

            <li><a href="#level_1">заголовок</a></li>

            <li><a href="#level_2">заголовок2</a></li>

          </ol>

        </li>

        <li><a href="#paragraph_2">заголовок</a></li>

    </ol>

    <ol class="count">

        <a name="paragraph_1"></a><li></li>

        <h2>Заголовок</h2>

        <a name="paragraph_2"></a><li></li>

        <h2>Заголовок</h2>';

    preg_match_all('#class="count_levels">(.+?)</ol>#is', $example, $arr);

    echo str_replace($arr[1][0] , $arr[1][0]."\n <b style='color:red;'>Добавляемый элемент</b>" , $example);

    Решение, которое работает всегда!

    Интересно, что самые не элегантные решения - работают всегда!

    Итак... что нам надо?

    Нам нужна функция... которая удаляет пустые ячейки массива + восстанавливает нумерацию массива.

    function dec(array $array, array $symbols = array('', NULL, false)) { return array_diff(array_map('trim', $array), $symbols); }

    Далее... нам нужно получить все до первого:

    <ol class="count">

    Разобьем в массив с помощью explode и получим первую часть массива используя current

    current(explode('<ol class="count">', $example))

    Мы получим :

    <ol class="count_levels">
      <li><a href="#paragraph_1">заголовок</a></li>
      <li><a href="#paragraph_2">заголовок</a></li>
    Сюда требуется добавить
    </ol>

    Теперь - я могу разбить полученный код по "</li>" и я знаю точно, что в предпоследней ячейке будет лежать моя строка(paragraph_2)...

    explode('</li>', "первая часть")

    И далее... заменяем предпоследнюю строку в начальном тексте:

    $example =str_replace($arr[count($arr)-2].'</li>' , $arr[count($arr)-2].'</li>'.'Добавляемый элемент' , $example);
    посмотреть результат...
    Соберем весь код:

    function dec(array $array, array $symbols = array('', NULL, false)) { return array_diff(array_map('trim', $array), $symbols); }

    $example = '

    <ol class="count_levels">

      <li><a href="#paragraph_1">заголовок</a>

        <ol class="count_levels">

          <li><a href="#level_1">заголовок</a></li>

          <li><a href="#level_2">заголовок2</a></li>

        </ol>

      </li>

      <li><a href="#paragraph_2">заголовок</a></li>

    </ol>

    <ol class="count">

      <a name="paragraph_1"></a><li></li>

      <h2>Заголовок</h2>

      <a name="paragraph_2"></a><li></li>

      <h2>Заголовок</h2>';

    $arr = dec( explode('</li>', current(explode('<ol class="count">', $example))));

    echo str_replace($arr[count($arr)-2].'</li>' , $arr[count($arr)-2].'</li>'."<b style='color:red;'>Добавляемый элемент</b>" , $example);

Не стесняемся говорить спасибо!
Помочь проекту DwWeb.ru

Поделиться ссылкой! C друзьями или врагами!

Этим вы очень поможете проекту! Заранее огромное спасибо!

Ещё : dwweb.ru есть здесь:
ruweb
Все статьи авторские, при копироавании активная ссылка обязательна DwWeb.ru! © 2015 - 2024 Контакты. Реклама на сайте Лучший хостинг : RUWEB + помощь по RUWEB
Страница загружена за : 0.017261 секунд. Подробнее