СКРИПТЫ
ТЕГИ:
php (284)
js (166)
html (138)
css (116)
html tags (61)
jquery (40)
edit text (37)
php array (30)
form html (29)
fonts (27)
ruweb.net (23)
foto (22)
online (20)
atom (20)
forum (19)
svg (18)
Показать еще :
board (17)
hosting (17)
php file (16)
html book (16)
js method (16)
input (15)
color (15)
php date (15)
link (15)
js events (14)
osclass (13)
table (13)
htaccess (13)
path (12)
js delete (12)
dw block (12)
select (12)
download (11)
icon (11)
jsphp (11)
php time (11)
img (11)
keyboard (11)
notepad (11)
php img (11)
form (11)
url (10)
mouse (10)
yandex (9)
info (9)
js time (9)
task (7)
dosite (7)
php url (7)
hover (7)
cookie (7)
comment (7)
js url (6)
mysql (6)
list (6)
year (6)
click (6)
iframe (6)
ftp (5)
search (5)
chart (5)
browser (5)
php get (5)
mb (5)
js id (5)
value (5)
adminka (5)
heading (5)
mounth (4)
bbcode (4)
symbols (4)
vk (4)
day (4)
console (4)
js form (4)
reg.ru (4)
submit (4)
week (4)
js img (3)
line (3)
captcha (3)
ucoz (3)
https (3)
js post (3)
ssl (3)
padding (3)
vs code (3)
scandir (3)
pages (3)
рся (2)
second (2)
money (2)
youtube (2)
video (2)
js vars (2)
seo (2)
typeof (2)
sitemap (2)
title (2)
tag hr (2)
cursor (2)
counter (2)
arrows (2)
base64 (2)
qr kod (2)
details (2)
height (2)
куб (1)
books (1)
scroll (1)
domen (1)
numbers (1)
google (1)
header (1)
windows (1)
smile (1)
speed (1)
archive (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 delite_empty_xell(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 delite_empty_xell(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 = delite_empty_xell( 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);

Пользуйтесь на здоровье! Не забудьте сказать спасибо
Теги :
Еще никто не прокомментировал! COMMENTS+   BBcode
аватар
🞨
Загрузить свой аватар
(max ширина, высота = 200px)

Подписаться + =

Последние комментарии :
вывы :
05.06.2022 12:32
сейчас яндекс добавил индексацию js в…
подробнее.
Марат :
02.06.2022 20:14
Михаил :
02.06.2022 20:10
Ну вот только для этого может быть ;) А так, нет смысла…
подробнее.
Марат :
02.06.2022 15:59
Чтобы вы зашли на данную страницу и нажали на…
подробнее.
Михаил :
02.06.2022 14:33
Ну вот только для этого может быть :) А так, нет смысла…
подробнее.
Алексей :
26.05.2022 14:19
👍👍👍
подробнее.
ruweb
Страница загружена за : 0.021605 секунд. Подробнее