Регулярные выражения - нужна помощь
Опубликовано пт, 22/01/2010 - 04:24 пользователем vadimmo
Forums: Захотелось заменить двухсимвольное сочетание пробел, длинное тире на неразрывный пробел, длинное тире во всей книге. Во всех версиях FBE, FBW можно использовать регулярные выражения при поиске, замене (а как иначе задать в строке замены неразрывный пробел?). Не получается. Такой символ - \x20 (обычный пробел) - находит. \xA0 (неразрывный пробел) - нет.
|
Вход на сайтПоиск по блогам и форумамUser menuПоследние комментарии
monochka RE:Подайте бедному копеечку на книжку с литреса... 5 часов
Larisa_F RE:Серия "Новые сказочные повести" издательство "Самовар" ... 1 неделя sem14 RE:Серия "Символы времени" издательства "Аграф" 1 неделя Larisa_F RE:Серия книг «Судьбы книг» издательства «Книга» 2 недели tvv RE:faq brainstorm =) 2 недели Larisa_F RE:Серия "Что есть что" издательства "Слово"(чего не хватает) 2 недели Larisa_F RE:Серия "Очень прикольная книга", издательство Азбука-классика 2 недели larin RE:абонемент не обновлен 3 недели sem14 RE:За иллюминатором (серия) - чего не хватает? 3 недели sem14 RE:Собираем серию: "Мастер серия", издательство "Лимбус". 3 недели Larisa_F RE:Книжная серия «Сlio» издательства "Евразия" 3 недели larin RE:Пропал абонемент 1 месяц tvv RE:DNS 1 месяц MrMansur RE:<НРЗБ> 1 месяц Stager RE:Беженцы с Флибусты 1 месяц Tramell RE:Серия "Библиотека французской литературы" (Макбел) 1 месяц sem14 RE:Книжная серия "Жизнь в искусстве" издательство "Искусство"... 1 месяц sem14 RE:Современная корейская литература. Книжная серия... 1 месяц Впечатления о книгах
MrMansur про Дубнов: Книга жизни [воспоминания и размышления] (Биографии и Мемуары)
07 02 Так есть же в формате fb2 http://209.42.197.18/b/786038
MrMansur про Прилепин: Тума (Современная проза)
07 02 Первая мысль - как же много крови проливали. Но потом осознание: почему проливали? Так было, ьак есть и так будет пока существует эта раковая опухоль - человек... Владея русским и татарским, было интересно читать многоязычные ……… Оценка: отлично!
polyn про Корсакова: Лисье золото [СИ litres] (Ужасы, Триллер, Самиздат, сетевая литература)
07 02 Очень интересное начало серии Оценка: отлично!
udrees про Каменистый: Запрещённый юг (Боевая фантастика, Фэнтези, Попаданцы, ЛитРПГ)
07 02 Смешно написано, продолжение хорошее. Понравится любителям серии. Герой снова попадает в переделки, снова сражается с сильными противниками, и снова получает кучу прогресса. Описания статов и достижений иногда могут раздражать, ……… Оценка: отлично!
udrees про Атаманов: Новые Боги (Боевая фантастика, ЛитРПГ, Самиздат, сетевая литература)
07 02 Смешное окончание приключений. Все было бы хорошо, если бы не вмешательство богов в дела земные. Хотя конечно изначально все предупреждены, что они игроки в большой Игре. Но в 4-й книге приключения в своем стиле, интересные ……… Оценка: хорошо
udrees про Атаманов: Верховья Стикса [СИ] (ЛитРПГ, Самиздат, сетевая литература)
07 02 Я полагаю не вторая, а третья книга может быть окончанием всей серии. Концовку чуть поменять и все, логический венец приключений гоблина. Собственно, в таком же стиле грамотное описание приключений гоблина, победы над сильными ……… Оценка: хорошо
udrees про Атаманов: Сохранить крылья [СИ] (ЛитРПГ, Самиздат, сетевая литература)
07 02 Совершенно сумасшедшее продолжение истории про приключения гоблина-травника в игровом мире, заодно перемежающееся с событиями в реальном мире. Автор часто использует такой прием в своих книгах. Не знаю, в «Забаненном» меня ……… Оценка: хорошо
alexk про Цзи Юнь: Заметки из хижины «Великое в малом» [сборник litres] (Древневосточная литература)
07 02 Издание повторяет старый советский вариант, только предисловие выкинули. И издание, и сам файл хуже предшественника.
decim про Смурыгина: Дефицит. Как в СССР доставали то, что невозможно было достать (История, Публицистика)
05 02 Даже забег по мос. лавкам в понедельник приносил урожай, а уж в посёлках чего только не было. Среди тамошнего населения считалось предосудительным носить не то, что принято - т.е. спецовку на каждый день и старый шерстяной ………
Barbud про Трофимов: Толмач [litres] (Боевая фантастика, Попаданцы)
05 02 Автор успел накропать уже целую охапку писева про данный исторический период, но так и не озаботился получше узнать о реалиях того времени, хотя бы учебник истории почитать - ну да, чукча не читатель, чукча писатель. Тут у ……… Оценка: плохо
irukan про Ланцов: Шанс (Альтернативная история, Социальная фантастика, Самиздат, сетевая литература)
04 02 Хорошо зашла книга! На одном дыхании прочёл. Давно у Ланцова такого не было. Наш совеременник попадает в Константинополь за несколько лет до его падения. То есть, понимаешь, что всё у него получится, но всё равно до конца держит в напряжении Оценка: отлично!
blahblah про Смурыгина: Дефицит. Как в СССР доставали то, что невозможно было достать (История, Публицистика)
04 02 Ужасная книга! Автор интервьюировала знаменитых людей, которые в тоже время в большинстве своём были детьми и внуками других знаменитых людей, ездили за границу, жили в привилегированных домах, получали спецпайки, джинсы во ……… Оценка: плохо |
Отв: Регулярные выражения - нужна помощь
А копипаст тоже не работает?
В смысле скопировать нужное из боди файла в строку замены.
Отв: Регулярные выражения - нужна помощь
Попробовал. Вместо неразрывного пробела вставляется простой. :(
Отв: Регулярные выражения - нужна помощь
Проблема снята использованием 16-ричного редактора
Отв: Регулярные выражения - нужна помощь
Можно ещё AkelPad и аналогичные использовать...
Отв: Регулярные выражения - нужна помощь
Да, спасибо, действительно Akelpad годится
Отв: Регулярные выражения - нужна помощь
В FBE2 делал контекстной заменой строки из пробела и тире на неразрывный и тире при включенных регулярных выражениях - проходило. Символ "пробел" вводил просто как " ", "неразрывный пробел" копипастил из штатной микро$офт-форточной софтинки "character map".
Тонкость: в режиме regexp неразрывный пробел тоже находится вместо обычного. Поэтому приходится повыкобениваться с серией замен:
- переключаюсь в режим исходника;
- меняю "<p> " на "<p>";
- "<v> " на "<v>";
- длинное тире на любой символ, которого в тексте гарантированно нет (к примеру, "доллар");
- пробел-доллар-пробел на неразрывный-тире-пробел;
- (ё-пс, забыл - поправляю) <p>-доллар-пробел на <p>-тире-неразрывный;
- <v>-доллар-пробел на <v>-тире-неразрывный;
- ищу все оставшиеся "доллары", правлю руками.
Ну, и неплохо поискать последовательности "пробел-минус" и "минус-пробел" - бывают неуверенно распознанные сканером или изгаженные при изготовлении .doc из .txt.
Отв: Регулярные выражения - нужна помощь
любой пробел (хоть в сорцах, хоть в обычном режиме):
\s
Отв: Регулярные выражения - нужна помощь
Кстати, а не подскажешь regexp для "европейских" букв (с галочками, акутами, умляутами и прочими хвостиками)? А то иногда досаждают - то из-за кривости исходной кодировки, а то есть умники, которые их пихают вместо ударений... :-(
Отв: Регулярные выражения - нужна помощь
Вот это подойдет?
http://miraduga.com/Temp/TablSpec.html
Отв: Регулярные выражения - нужна помощь
Можешь сам подобрать.
Таблицу символов выводишь на экран (на виндоус:
%SystemRoot%\system32\charmap.exe) и начинаешь исключать диапазоны и символы.[^!-¿]- уберет латинский и распространенные символы[^!-¿а-яё]- тоже самое + русский[^!-¿а-яё\s–—…„“]- с этим уже можно работать.По вкусу, в общем.
Отв: Регулярные выражения - нужна помощь
Отв: Регулярные выражения - нужна помощь
для подобной чистки я использую либо скрипт «Генеральная уборка», либо внешние средства регэкспов (хоть тот же AkelPad), поэтому такие проблемы были для меня новостью, и я решил поразбираться. результаты приведены ниже. до кучи последним пунктом добавил свое давнее наблюдение.
Отв: Регулярные выражения - нужна помощь
Отв: Регулярные выражения - нужна помощь
И вот еще что есть:
Регекспы от Грибова (входят в дистрибутив Ocr Pad)
http://narod.ru/disk/17203841000/RegExp.html.zip.html
Отв: Регулярные выражения - нужна помощь
Посмотрев на ситуацию с неразрывными пробелами, я опечалился и озадачился.
Вручную расстановка этого дела - трудоёмкое занятие. Даже если делать с использованием рег.выражений.
Видимо, напишу программку на Python. Займёт какое-то время, зато есть надежда, можно будет автоматически расставлять неразрывные пробелы по всей книге сразу.
Ещё правильней было бы сделать на javascript. Мне не хочется.
Отв: Регулярные выражения - нужна помощь
А чем не устраивает вышеупомянутый скрипт "Генеральная уборка"? он широко используется (в узком кругу :)) для чистки fb2
Отв: Регулярные выражения - нужна помощь
Да у меня из-за проблем со стабильностью программы скрипты почти никакие не работали. Сейчас, когда проблема решена, можно посмотреть, что и как работает из скриптов.
Отв: Регулярные выражения - нужна помощь
Попробовал скрипт "Генеральная уборка". Отличный скрипт. Только неразрывные пробелы он не расставляет, а удаляет.
Отв: Регулярные выражения - нужна помощь
насколько я помню, от ставит неразрывный пробел не перед всеми тире, а только, если перед пробелом есть знак препинания, а также после тире прямой речи.
Отв: Регулярные выражения - нужна помощь
В код не заглядывал, но прогнал текст один раз - скрипт про неразрывные пробелы ничего не сказал. Поставил вручную один неразрывный пробел. Результат - http://ifotka.ru/images/l8lhz486rmwhbegwd1dz.png
Отв: Регулярные выражения - нужна помощь
я тоже не заглядывал в код. лучше сделать так:
выполнить скрипт, документ сохранить как name1;
во внешнем редакторе открыть name1, заменить все неразрывные на простые, сохранить как name2;
снова в FBE открыть name2, выполнить скрипт, сохранить как name3;
в любимой программе сравнения посмотреть на разницу между name2 и name3.
Отв: Регулярные выражения - нужна помощь
Отв: Регулярные выражения - нужна помощь
Гы-ы. А в бесплатном WinMegre пробелы учитываются, причем дифференцированно - обычные и неразрывные.
Отв: Регулярные выражения - нужна помощь
Upd: невезуха - не берётся, админы уже успели закрыть закачку .exe-файлов и доступ к самым популярным файлообменникам. :-( Смогу скачать только вечером из дому.
Upd2: скачал, пробую. Непривычно - сравниваемые тексты не сверху-снизу, а слева-справа. А особенно жаль, что нету моих любимых регулярных выражений, в коих так удобно собирать отличия, которые я намерен проигнорировать (разные кавычки, тире, даже имена - в "Туманности Андромеды, например: Эрг Ноор, Ионе Мар, Мвен Мас - то латиницей, то кириллицей).
Отв: Регулярные выражения - нужна помощь
Положение окошек можно поменять в настройках. И никто не говорил,что будет легко :). Можно им пользоваться только для
окончательных расчётовпоследней проверки именно пробелов, после прогона ч/з CompareIt.Я, конечно, понимаю, что лучше быть и здоровым и богатым, но делать-то нечего.
Отв: Регулярные выражения - нужна помощь
Отв: Регулярные выражения - нужна помощь
(каеццо) Не-е-е. Наврала я. Там в "окна" есть переключатель - горизонтальное и вертикальное расположение окон, но это не то, не на те окошки действует, перепутала. :( Мне-то как раз удобно, как тебе не удобно. :))
Отв: Регулярные выражения - нужна помощь
подсказка… в вышеописанной схеме программа сравнения не обязана быть текстовой: для установления факта, что в name2 — обычные пробелы, а в name3 — неразрывные, достаточно fc /b
Отв: Регулярные выражения - нужна помощь
Отв: Регулярные выражения - нужна помощь
я не понял, в чем проблема. поковырялся я с этой прогой — замечательно себя ведет, дай бог каждой. можно визуализировать пробельные символы, так там все, как на ладоне. если включить игнор пробельных, то естественно всякие пробелы, табы и пр. в безразличном количестве не будут принимать участие в сравнении.
надо будет поактивнее эту прогу пользовать, а то что-то она у меня простаивает :)
Отв: Регулярные выражения - нужна помощь
Отв: Регулярные выражения - нужна помощь
Отв: Регулярные выражения - нужна помощь
Да, это бандитизм. Я после "генеральной уборки" дополнительно делаю общую замену пробел + тире на неразрывный пробел + тире.
Отв: Регулярные выражения - нужна помощь
Когда вставлены неразрывные пробелы в Alreader'е не работает поиск, если в строке поиска есть пробел, а на самом деле там неразрывный пробел. Это скорее претензия к читалке. В Coolreader3 поиска вообще не нашёл.