Объединить несколько jpg в один pdf в Linux

я использовал следующую команду для преобразования и объединения всех jpg файлы в каталоге в один pdf-файл.

convert *.jpg file.pdf

файлы в каталоге пронумерованы от 1.jpg to 123.jpg. Конвертация прошла хорошо, но после преобразования страницы были все перепутаны. Я хотел, чтобы pdf-файл имел страницы из 1.jpg to 123.jpg в том же порядке, как они названы. Я также попытался выполнить следующую команду:

cd 1 
FILES=$( find . -type f -name "*jpg" | cut -d/ -f 2)
mkdir temp && cd temp 
for file in $FILES; do 
    BASE=$(echo $file | sed 's/.jpg//g');
    convert ../$BASE.jpg $BASE.pdf; 
    done && 
pdftk *pdf cat output ../1.pdf && 
cd .. 
rm -rf temp

но все равно не повезло. Операционная платформа Линукс.

6 ответов


проблема в том, что ваша оболочка расширяет подстановочный знак в чисто алфавитном порядке, и поскольку длины чисел разные, порядок будет неправильным:

$ echo *.jpg
1.jpg 10.jpg 100.jpg 101.jpg 102.jpg ...

решение состоит в том, чтобы заполнить имена файлов нулями, как требуется, чтобы они были одинаковой длины перед запуском команды convert:

$ for i in *.jpg; do num=`expr match "$i" '\([0-9]\+\).*'`;
> padded=`printf "%03d" $num`; mv -v "$i" "${i/$num/$padded}"; done

Теперь файлы будут сопоставлены подстановочным знаком в правильном порядке, готовые для команды convert:

$ echo *.jpg
001.jpg 002.jpg 003.jpg 004.jpg 005.jpg 006.jpg 007.jpg 008.jpg ...

или просто читать ls инструкцию и видите :

- V естественный вид (версия) чисел в тексте

Итак, делаем то, что нам нужно в одну команду.

convert `ls -v *.jpg` foobar.pdf

удачи ;) Ф.


вот как я это делаю:
Первая строка конвертирует все файлы jpg в pdf с помощью команды convert.
Вторая строка объединяет все pdf-файлы в один файл в формате pdf на странице. Это с помощью gs ((PostScript и pdf переводчик языка и просмотрщик))

for i in $(find . -maxdepth 1 -name "*.jpg" -print); do convert $i ${i//jpg/pdf}; done
gs -dNOPAUSE -sDEVICE=pdfwrite -sOUTPUTFILE=merged_file.pdf -dBATCH `find . -maxdepth 1 -name "*.pdf" -print"`

все вышеперечисленные ответы не удались мне, когда я хотел объединить много изображений jpeg с высоким разрешением (из отсканированной книги).

Imagemagick попытался загрузить все файлы в ОЗУ, поэтому я использовал следующий двухэтапный подход:

find -iname "*.JPG" | xargs -I'{}' convert {} {}.pdf
pdfunite *.pdf merged_file.pdf

обратите внимание, что при таком подходе вы также можете использовать GNU parallel для ускорения преобразования:

find -iname "*.JPG" | parallel -I'{}' convert {} {}.pdf

смешивая первую идею с их ответом, я думаю, что этот код может быть удовлетворительным

jpgs2pdf.sh

#!/bin/bash

cd 
FILES=$( find . -type f -name "*jpg" | cut -d/ -f 2)
mkdir temp > /dev/null
cd temp

for file in $FILES; do
 BASE=$(echo $file | sed 's/.jpg//g');
 convert ../$BASE.jpg $BASE.pdf;
done &&

pdftk `ls -v *pdf` cat output ../`basename `.pdf
cd ..
rm -rf temp

вы могли бы использовать

convert '%d.jpg[1-132]' file.pdf

via https://www.imagemagick.org/script/command-line-processing.php:

другой способ ссылки на другие файлы изображений-это встраивание форматирование символа в имени файла с диапазоном сцен. Рассмотрим именем image-%d.jpg[1-5]. Команда

magick image-%d.jpg[1-5] заставляет ImageMagick пытаться читать изображения с этими именами:

image-1.jpg image-2.jpg image-3.jpg image-4.jpg image-5.jpg

посмотреть также https://www.imagemagick.org/script/convert.php