通常、トリミングされた出力は通常より多くのディスク容量を消費しますが、 pdfcrop
を使用することでかなり満足しています。同等の codedoesが存在することに注意してください。これにより、この問題に対処して解決します。ただし、スキャンされた(イメージ)pdfファイルを切り取りたい場合、pdfcrop
は単に失敗するだけです。 ImageMagick
は、おそらく pdftk
を(また)作成することによって、トリックを行うことができると思います。
このようなpdfファイルをTop-Bottom-Left-and-Rightからx cmずつトリミングするための効率的な1行のコード(複数行のスクリプトでもOKです...)を探しています(または、より良いまだ、abcd cmで、個別に)、input.pdfからoutput.pdfまでずっと進みます。
ps:ソリューションにImageMagick
を含める必要はありません。 (きれいに、確実に、効率的に)動作する限り、私は幸せです...;)
完全な功績は AlexG 偶然en passantがこの問題の解決策を投稿したためです here 迷子にならないように(!)、以下に引用します。
上記の質問に関連するのは、man
で説明されているtrimmingオプションです。
使用例:
#default operation pdfcrop.sh orig.pdf cropped.pdf pdfcrop.sh -m 10 orig.pdf cropped.pdf pdfcrop.sh -hires orig.pdf cropped.pdf #trimming pages pdfcrop.sh -t "10 20 30 40" orig.pdf trimmed.pdf
pdfcrop.sh
のコンテンツ:#!/bin/bash function usage () { echo "Usage: `basename $0` [Options] <input.pdf> [<output.pdf>]" echo echo " * Removes white margins from each page in the file. (Default operation)" echo " * Trims page edges by given amounts. (Alternative operation)" echo echo "If only <input.pdf> is given, it is overwritten with the cropped output." echo echo "Options:" echo echo " -m \"<left> [<top> [<right> <bottom>]]\"" echo " adds extra margins in default operation mode. Unit is bp. A single number" echo " is used for all margins, two numbers \"<left> <top>\" are applied to the" echo " right and bottom margins alike." echo echo " -t \"<left> [<top> [<right> <bottom>]]\"" echo " trims outer page edges by the given amounts. Unit is bp. A single number" echo " is used for all trims, two numbers \"<left> <top>\" are applied to the" echo " right and bottom trims alike." echo echo " -hires" echo " %%HiResBoundingBox is used in default operation mode." echo echo " -help" echo " prints this message." } c=0 mar=(0 0 0 0); tri=(0 0 0 0) bbtype=BoundingBox while getopts m:t:h: opt do case $opt in m) eval mar=($OPTARG) [[ -z "${mar[1]}" ]] && mar[1]=${mar[0]} [[ -z "${mar[2]}" || -z "${mar[3]}" ]] && mar[2]=${mar[0]} && mar[3]=${mar[1]} c=0 ;; t) eval tri=($OPTARG) [[ -z "${tri[1]}" ]] && tri[1]=${tri[0]} [[ -z "${tri[2]}" || -z "${tri[3]}" ]] && tri[2]=${tri[0]} && tri[3]=${tri[1]} c=1 ;; h) if [[ "$OPTARG" == "ires" ]] then bbtype=HiResBoundingBox else usage 1>&2; exit 0 fi ;; \?) usage 1>&2; exit 1 ;; esac done shift $((OPTIND-1)) [[ -z "$1" ]] && echo "`basename $0`: missing filename" 1>&2 && usage 1>&2 && exit 1 input=$1;output=$1;shift; [[ -n "$1" ]] && output=$1 && shift; ( [[ "$c" -eq 0 ]] && gs -dNOPAUSE -q -dBATCH -sDEVICE=bbox "$input" 2>&1 | grep "%%$bbtype" pdftk "$input" output - uncompress ) | Perl -w -n -s -e ' BEGIN {@m=split /\s+/, $mar; @t=split /\s+/, $tri;} if (/BoundingBox:\s+([\d\.\s]+\d)/) { Push @bbox, $1; next;} elsif (/\/MediaBox\s+\[([\d\.\s]+\d)\]/) { @mb=split /\s+/, $1; next; } elsif (/pdftk_PageNum\s+(\d+)/) { $p=$1-1; if($c){ $mb[0]+=$t[0];$mb[1]+=$t[1];$mb[2]-=$t[2];$mb[3]-=$t[3]; print "/MediaBox [", join(" ", @mb), "]\n"; } else { @bb=split /\s+/, $bbox[$p]; $bb[0]+=$mb[0];$bb[1]+=$mb[1];$bb[2]+=$mb[0];$bb[3]+=$mb[1]; $bb[0]-=$m[0];$bb[1]-=$m[1];$bb[2]+=$m[2];$bb[3]+=$m[3]; print "/MediaBox [", join(" ", @bb), "]\n"; } } print; ' -- -mar="${mar[*]}" -tri="${tri[*]}" -c=$c | pdftk - output "$output" compress
brissを試すことができます。それは非常に簡単ですが、仕事をします。ただし、GUIアプリです。
Zipファイルをダウンロードし、選択したフォルダーに解凍して開始します。
Java -jar briss-0.9.jar
システム全体に永続的にインストールし、briss
だけでどこからでも起動できるようにするには、ダウンロードを/usr/local/lib/
に解凍し、次を含む実行可能ファイル/usr/local/bin/briss
を作成します。
#!/bin/sh
Java -jar /usr/local/lib/briss-0.9/briss-0.9.jar
これはここで最良かつ最も簡単で、素晴らしいGUIがあります:Krop
著者からdebをダウンロード: http://arminstraub.com/computer/krop
レビュー: http://www.hecticgeek.com/2013/08/crop-pdf-ubuntu-13-04-krop/
編集:13.10からkropを使用していますが、最新バージョンでは、右クリックでkropでPDFを開くことができるようになりました。 18.10と19.04で確認されたスナップバージョンも利用可能になり、右クリックもサポートされるようになったため、スナップバージョンに切り替えました。 GUIはスナップバージョンほどカラフルではありませんが、機能は同じです。
Sudo snap install krop