2

Есть ли способ сделать PDF только из скрытого текстового слоя файла DjVu?

Я умею пользоваться

djvused myfile.djvu -e 'output-txt' > myfile.dsed

вывести сценарий DjVu, который включает координаты x, y каждого слова каждой страницы, но как мне преобразовать это в PS или PDF? Я уверен, что у кого-то есть сценарий.

Файл dsed начинается с таких S-выражений (нажмите здесь для получения дополнительной информации):

select; remove-txt

# ------------------------- 

select "myfile_0000.djvu"
set-txt
(page 108 107 1176 1725
 (column 941 1694 1176 1725
  (region 941 1694 1176 1725
   (para 941 1694 1176 1725
    (line 941 1694 1176 1725
     (word 941 1694 999 1723 "another")
     (word 1024 1696 1176 1725 "word")))))
 (column 108 107 805 1519
  (region 108 107 805 1519
   (para 226 1491 701 1519
    (line 226 1491 701 1519
     (word 226 1491 701 1519 "example")))
   (para 350 1370 534 1396

так далее…

Спасибо

2 ответа2

0

Самый простой способ сделать это - преобразовать DjVu в PDF (убедившись, что слой OCR поддерживается в PDF). Затем запустите:

gs -q -o - -dFILTERIMAGE -sDEVICE=pdfwrite -f "${input_pdf}" | pdftk - output - uncompress | sed "s/^3 Tr$/0 Tr/g" | pdftk - output "${output_pdf}" compress

где пользователь указывает ${input_pdf} и ${output_pdf} . gs удаляет (-dFILTERIMAGE) все изображения, а sed делает так, чтобы PDF-файл отображал скрытый текст OCR как видимый (изменяя для команды 3 Tr PDF или "рендеринга скрытого текста" значение 0 Tr или "рендеринга текста по умолчанию"). Последняя команда pdftk не является строго необходимой, но первая - иначе, sed не сможет изменить команду PDF Tr .

0

Обновлено после ввода OP:

Чтобы ввести тип слоя OCR слоя DJVU в файл PDF, то есть напечатать слова в том месте, в котором они появляются в файле DJVU, один из вариантов заключается в программной генерации файла Inkscape или Scribus. Я нарисую процедуру. Нетрудно написать скрипт на выбранном вами языке (Python, Ruby, Racket и т.д.).

  1. Для каждой страницы файла DJVU экспортируйте слой OCR как HTML или как S-выражение. Я буду предполагать последнее в следующем.

  2. Извлеките размер страницы из (page x1 y1 x2 y2... Ширина страницы = x2-x1 , высота страницы = y2-y1.

  3. Для каждого слова рассчитайте ширину, высоту и координаты нижнего левого угла текстового фрейма, в котором он будет находиться. То есть превратить (word x1 y1 x2 y2 "another") в текстовую рамку с левым нижним углом в (x1, Page height - y1) , шириной x2 - x1 и высотой y2 - y1 .

  4. Выберите подходящий шрифт и размер шрифта для текстового фрейма. Используйте высоту прямоугольников слова в качестве руководства. Убедитесь, что текст не растянут по размеру текстового фрейма.

  5. Как только вы закончите добавление всех текстовых фреймов на страницу, экспортируйте файл в PDF. Обратите внимание, что размер страницы намного больше, чем буква или А4. Если вы собираетесь распечатать документ, убедитесь, что он масштабирован в диалоговом окне печати, чтобы соответствовать размеру бумаги. Чтобы сохранить деревья, сначала распечатайте в файл PDF.

Оригинальный ответ:

Согласно man djvused , команда 'output-txt' сгенерирует скрипт djvused , который предназначен для потребления djvused .

Для ваших целей лучше использовать (согласно man-странице)

djvused myfile.djvu -e 'print-pure-txt' > myfile.txt

Затем вы можете создать PDF-файл с помощью программы, которая может печатать в PDF.

В зависимости от вашей операционной системы и версии вам может потребоваться установить принтер PDF. Вы также можете открыть его в последней версии Chrome или Firefox и распечатать в PDF.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .