Вы здесьУдаление дублей из архивов по 1000 книг.
Опубликовано вт, 20/01/2009 - 15:27 пользователем Bullfear
Есть такая программа myhomelib. Для работы использует архивы либрусека. В этих архивах примерно 20% дублей. В связи с этим возникает вполне закономерное желание эти дубли убрать. pkn написал для этой цели скрипт. Скрипт перловый.
|
Вход на сайтПоиск по блогам и форумамUser menuПоследние комментарии
weis RE:Прошу переформатировать, распознать, etc... 3 дня
Океана RE:Подайте бедному копеечку на книжку с литреса... 23 часа larin RE:Заплатила, а абонемента нет и скачать ничего не могу! 1 неделя sibkron RE:Серия "Библиотека французской литературы" (Макбел) 1 неделя akorish RE:Регистрация 1 месяц Tramell RE:Серия "Очень прикольная книга", издательство Азбука-классика 1 месяц Larisa_F RE:Серия "Я познаю мир" издательства "АСТ, Астрель, Олимп",... 1 месяц konst1 RE:Ух, как я не люблю спамеров! 1 месяц tvv RE:DNS 1 месяц sem14 RE:«Не забыть бы тогда, не простить бы и не потерять!»-2 ... 1 месяц larin RE:Заблокирован 2 месяца konst1 RE:Серия «Интеллектуальный детектив» изд-ва АСТ 2 месяца Larisa_F RE:Серия книг «Судьбы книг» издательства «Книга» 2 месяца fixel RE:Пропал абонемент 2 месяца sem14 RE:Книжная серия "Жизнь в искусстве" издательство "Искусство"... 3 месяца sibkron RE:"100 славянских романов", серия изд.-ва "Центр книги... 3 месяца Larisa_F RE:Серия "Новые сказочные повести" издательство "Самовар" ... 4 месяца sem14 RE:Серия "Символы времени" издательства "Аграф" 4 месяца Впечатления о книгах
Gilean про Алим Тыналин
09 06 Все книги читабельны )) Прочитал серию Биржевик, Фарцовщик и читаю Криминалиста. Мне нравится, неплохая подача материала, да и ошибок в тексте мало.
Sello про Пинчон: Выкрикивается лот 49 [The Crying of Lot 49 ru] (Современная проза)
09 06 Начальный Пинчон", - сыроват, с некоторыми неувязками (например, после связи с Метцгертом, Эдипа, размышляя, говорит о "своем единственном любовнике", забывая почему-то об "основном", Пирсе), немного затянут в поисках ответа ……… Оценка: хорошо
Chernovol про Созонтов: История России в датах. 100 главных событий (История)
08 06 Пропущенные вехи истории: голодомор, ввод советских войск в Чехословакию. А советские войска не вошли, а напали на Польшу в 1939 г. Оценка: неплохо
Никос Костакис про Шиляев: Телохранитель Генсека. Том 7 [СИ] (Альтернативная история, Попаданцы, Самиздат, сетевая литература)
08 06 о присвоении его к званию Героя Советского Союза" ____ Йа! Рузский йазыка есть очень трудное!
Barbud про Воронцов: Петербургский врач. Часть 1 [СИ] (Альтернативная история, Самиздат, сетевая литература)
08 06 Да что же такое, еще один попадун пенициллин на коленке варить собрался!) Впрочем, это же ИИшное творчество - нейросеть, наверное, просто выдернула из других, гораздо более одиозных опусов идею создания антибиотиков из подручных средств. Оценка: плохо
mysevra про Березин: Пентаграмма Осоавиахима [litres] (Альтернативная история, Современная проза, Городское фэнтези)
08 06 Как той собачке, ничего не светит, акцент выборочно-минорный. Но язык хорош, улыбнуло. Оценка: хорошо
mysevra про Мороз: Мгла [СИ] (Фэнтези, Самиздат, сетевая литература)
08 06 Сейчас много таких книг: золотая идея, оригинальная и интересная, а изложить человек не в состоянии – ни словарного запаса, ни фантазии, ни таланта плести словесные кружева или же просто изъясняться чётко и внятно. Таким надо ……… Оценка: неплохо
mysevra про Реньжина: Бабушка сказала сидеть тихо (Современная проза)
08 06 Эта книжка упоминалась в каком-то списке самых жутких историй, поэтому я и ждала чего-то запредельного и щекочущего воображение. А это просто женская проза, милая и грустная. Не люблю такое. Оценка: неплохо
xZiminxx про Воронцов: Петербургский врач. Часть 4 [СИ] (Альтернативная история, Самиздат, сетевая литература)
07 06 чем дальше тем хуже . это альтернативка или техническая литература? Оценка: нечитаемо
Lan2292 про Антонов: Портальщик. Частная практика [СИ] (Фэнтези, Попаданцы, Самиздат, сетевая литература)
07 06 Хорошая идея, но вот исполнение.... Не знаю, не стала дочитывать Оценка: неплохо
xZiminxx про Дорин: В небе 1941-го (Альтернативная история, Боевая фантастика, Самиздат, сетевая литература)
07 06 Автор в начале книги бред несет . В Украине бои ведутся 10-20 км до линии соприкосновения так что сбить его могли только в начале войны . да и героя могли дать за драмтеатор в Мариуполе 300-600 погибших Оценка: неплохо |
Комментарии
Отв: kop-librusec-dedead - очень новая версия.
Странно... параметры ОК, вроде должно было нормально сработать... правда, не видно нормально ли загрузились SQL-таблицы... нельзя ли полностью вывод скрипта увидеть?
Убедил. Как руки дойдут - сделаю.
Отв: kop-librusec-dedead - очень новая версия.
Изволь. Распаковка таблиц заняла чуть больше 20 минут. Дальше уже пошло убиение невиновных файлов, посему скрипт был безжалостно остановлен :) И так уже половину придется перекачивать.

Кстати по поводу sql... А работать по спискам myhomelib скрипт разучился? Если да, то жаль - было намного быстрее.
Отв: kop-librusec-dedead - очень новая версия.
Распаковка - это секунды, там парсинг длинный. Но это от компупера зависит, у меня это три минуты занимает :). Но учту, спасибо, если будет возможность - попробую эту часть ускорить.
Ну извини... я честно предупреждал: "НЕ пользуйтесь этой опцией, если не уверены." ;)
Не, это вряд ли получится. Я много пользуюсь частями именно этого скрипта, с SQL-таблицами, и поддерживать два формата - эт я не потяну.
Теперь по сути: похоже, там баг в скрипте. При единственном фильтре "по языку ru" он нашел всего 5409 желаемых (wanted) книг из 123760. Не может быть чтобы в таблицах было всего 5 тысяч книг на русском. И у меня такой же примерно результат, даже ещё меньше, так что это не разница в Перле или в SQL-таблицах, а баг в скрипте. Буду искать, как только дойдут руки. Постараюсь не затягивать, но прямо сейчас - не могу.
Отв: Удаление дублей из архивов по 1000 книг.
Ну дык на настольном и у меня будет около 3-х минут. Ты на ноуте пораспаковывай :Р
Тоесть косяк в единственном фильтре или именно в фильтре по языку?
*обиженным голосом* Но ты не добавлял "... что в скрипте нет бага" :Р
Ясно, спасибо. Бум ждать, благо сейчас либрусек работает и это не так критично ;)
Отв: Удаление дублей из архивов по 1000 книг.
Баг в скрипте есть всегда. Это аксиома.
kop-librusec-dedead - 0.4.3
kop-librusec-dedead верисия 0.4.3 - прицеплена к посту.
Изменения:
1. Пофиксен злобный баг. Предыдущими версиями не пользоваться, они глюкавые на всю голову!
2. Добавлена опция -testrun : Делать всё как настоящее, но не писать/стирать никаких zip-архивных файлов.
3. Добавлена возможность перезаписывать поверх исходных файлов. Для этого надо чтобы -do (dirout, выходной директорий) показывал туда же где лежат исходные зипы (dirzip), и присутствовала опция -removeoriginals.
Отв: kop-librusec-dedead - 0.4.3
Спасибо, щас потестим :)
Отв: kop-librusec-dedead - 0.4.3
Меня терзают смутные сомнения... На первый взгляд все нормально, однако почти в каждом архиве скрипт находит примерно 250-300 дублей. Так и должно быть? Архивы уже были обработаны старой (безглючной) версией скрипта.
Wanted total 96695
Books total 123760
to be squeezed 27065
Или он просто повторно обьединичивает единички? Тогда все в порядке.
Из замеченного: быстрее стали грузится таблицы, это гуд :)
А вот еще что.
WARNING: Bad member name: "Ketrin_A_List_Etika_bl**stva.fb2" zipf="16988-117987"
C этими файлами можно что-то сделать?
Отв: kop-librusec-dedead - 0.4.3
Повторно объединичивает.
Это тебе показалось :) там ничего не делалось.
АХЕЗ. Звёздочки в имени разрушают перловые regexp-ы. Я пока не могу научиться как бы их правильно сравнивать.
Отв: kop-librusec-dedead - 0.4.3
Странно. Тем не менее факт. Тогда одно из трех:
- Я сонный, поэтому думаю медленнее :)
- Они эээ... Закешировались виндой, ибо ноут уже недели две не перезагружался.
- Что третье? Говорю же - сонный я :Р
Отв: kop-librusec-dedead - 0.4.3
Можно экранировать переменную - /^\Q$membername\E$/
А можно использовать строковое сравнение вместо regexp (должно быть быстрее) - grep {$_ eq $membername} @FN_G;
Отв: kop-librusec-dedead - 0.4.3
Спасибо! Перловковар из меня тот ещё...
Страницы