@kuzkuz said in Как текст закинуть в массив по буквенно?:
Это как не покажете поподробнее?
А то у меня вот что получается и не работает
e93c1ee4-8dab-4881-8150-ea312348b8c6-изображение.png
@fox said in Как начать цикл по невидимым на странице объектам?:
Вот тестовый скрипт
BAS не открывает: ошибка загрузки файла start tag expected
Нажал кнопку перезагрузить скрипт - весь проект в БАСе полностью обнулился. И в папке backups все проекты пустые. Глючит софтина!
Я мышкой ссылку на рабочий стол перетянул, зашел в БАС и нажал открыть.
Это что то новенькое.. У меня при таких же манипуляциях создаётся ярлык на ссылку

Судя по всему браузер у тебя Google Chrome, скрипт в нём сохранить можно так:

@fox Точно, я не посмотрел что ссылка сохранилась, а не xml. Но весь проект у меня похерился точно не из-за этого: нажал перезапустить скрипт и все, в списке ни одного действия. И в бэкапах все сохраненки пустые, свои косяки я признаю, но это явно баг.
@fox Я без претензий, в любом случае спасибо. Просто тут чуть сложнее. Урлы выделены в красную рамочку на картинке в первом посте в этой теме.
"([[\s\S]*]/gmi)"
"([[\s\S]*])"
"([[\s\S]*?])"
Эти варианты тоже выдают пустой список. Я думал после этой регулярки применить вторую и получить что хочу, но почему-то и первая не работает.
"((http)(.*)(?=")/gmi)"
@olegtut said in Как начать цикл по невидимым на странице объектам?:
по каждому чиху беспокоить сапорта, ну перезагрузи прогу
Не помогло. Вообще странно, все шрифты как живые, шевелятся при движении мышью, смазываются. Именно после загрузки сайта происходит, в моих скриптах все нормально, только с этим файлом проблема.
Мне казалось, что автор этой реально полезной проги заинтересован сделать ее лучше. По крайней мере так написано. Если о багах разработчику знать не интересно и бесплатный QA не нужен я могу о них не писать.

@fox, спасибо. Стало на много понятнее. Можете прояснить еще несколько вопросов чтобы логику до конца понять:
Есть какая-то особенность, которая не позволяет извлечь одно совпадение с помощью "извлечь все данные"
Поддерживается или нет
/gmi
[([\s\S]*?)]
(http)(.*?)(?=")

@senerg said in Как начать цикл по невидимым на странице объектам?:
Мне казалось, что автор этой реально полезной проги заинтересован сделать ее лучше. По крайней мере так написано. Если о багах разработчику знать не интересно и бесплатный QA не нужен я могу о них не писать.
А где вы сообщаете о ошибках?
https://community.bablosoft.com/topic/2706/как-правильно-сообщить-об-ошибке
Есть какая-то особенность, которая не позволяет извлечь одно совпадение с помощью "извлечь все данные"
Действие "извлечь все данные" возвращает массив
Поддерживается или нет
/gmi
В стандартных действиях BAS нет. Но они поддерживаются в действии "выполнить код", где можно создать свой RegExp.
Круглые скобки здесь обязательны [([\s\S]*?)]
Круглые скобки сообщают о группе. Здесь само выражение неправильное, квадратные скобки это диапазон, [([\s\S] поиск символов открывающейся круглой скобки, открывающейся квадратной скобки, пробельного символа и не пробельного символа.
Почему во втором запросе не работает выделение до закрывающей кавычки
Что означает фраза "во втором запросе"?
@fox said in Как начать цикл по невидимым на странице объектам?:
Здесь само выражение неправильное
Я не то вставил, хотел вставить вот это из вашего скрипта:
[([\s\S]*?)]
Раз группы не используются значит круглые скобки для первого запроса не обязательны, правильно?
Первый и второй запросы:

Почему во втором запросе не работает выделение до закрывающей кавычки?
(http)(.*?)(?=")
Я не то вставил, хотел вставить вот это из вашего скрипта: [([\s\S]*?)]
У меня не такое выражение, присмотритесь, я экранировал внешние квадратные скобки.
Раз группы не используются значит круглые скобки для первого запроса не обязательны, правильно?
Почему группы не используются? оО
Почему во втором запросе не работает выделение до закрывающей кавычки? (http)(.*?)(?=")
Давай разберёмся что делает эта регулярка, ищем данные первой группы http, затем вторая группа это любой символ 0 и более раз, не жадные, третья группа это вперёд смотрящее утверждение. Ума не приложу зачем нужны три группы и утверждение..
Погоди, ты спрашиваешь почему твоя регулярка не работает, а моя работает? Убери утверждение в третьей группе
(http)(.*?)"
@fox said in Как начать цикл по невидимым на странице объектам?:
У меня не такое выражение, присмотритесь, я экранировал внешние квадратные скобки.
Вопрос был лишь в том обязательно ли любые символы отделять от экранированных квадратных скобок круглыми? Вот скрин из вашего скрипта:

Что делает регулярка:

Смотрящее вперед утверждение в БАС разве не работает? А если там вместо jpg появится png я тоже его хочу скачать.
обязательно ли любые символы отделять от экранированных квадратных скобок круглыми?
В круглые скобки я выделил лишь те данные, которые хочу получить, без лишних символов.
А если там вместо jpg появится png я тоже его хочу скачать.
Я первым сообщением в этой теме скинул регулярку
"(http.*?)"
Смотрящее вперед утверждение в БАС разве не работает?
А что по вашему означает "смотрящее вперед утверждение"?
Утверждения
Утверждение – это проверка символов, следующих до или после текущего символа. Простейшие утверждения закодированы последовательностями \A, \Z, ^, $ и т.д. Более сложные утверждения кодируются с помощью подшаблонов. Постараемся вкратце описать, как это делается.
Существует два типа утверждений: те, что смотрят на текущую позицию в исходной строке ( "смотрящие вперед" ), и те, что смотрят на символы перед текущей позицией ( "смотрящие назад" ).
Утверждения, закодированные подшаблонами, сравниваются как обычные подшаблоны, за исключением того, что при их обработке не происходит изменения текущей позиции.
"Смотрящие вперед" утверждения ищут совпадения в строке за текущей позицией поиска и начинаются с (?= для позитивных утверждений и с (?! для негативных. Например,
\w+(?=;)
совпадает со словом, заканчивающимся точкой с запятой (не включая точку с запятой в результат поиска), и
foo(?!bar)
совпадает с любым появлением foo, после которого нет bar.