要提取文件夹或文件夹中所有PDF的特定页,你可以使用Bash脚本配合使用pdftk工具和Ghostscript工具来实现。下面是一个解决方法,其中包含代码示例:
pdftk --version
gs --version
如果它们没有安装,请根据你的操作系统安装它们。
#!/bin/bash
# 指定输入文件夹路径和输出文件夹路径
input_folder="/path/to/input/folder"
output_folder="/path/to/output/folder"
# 循环遍历输入文件夹中的PDF文件
for file in "$input_folder"/*.pdf; do
# 提取文件名(不包括路径和扩展名)
filename=$(basename "$file" .pdf)
# 指定要提取的页码范围,比如提取第1页和第3页
page_range="1-3"
# 使用pdftk提取指定页码范围的页
pdftk "$file" cat $page_range output "$output_folder/$filename"_"$page_range".pdf
# 使用Ghostscript压缩提取的PDF文件(可选)
gs -sDEVICE=pdfwrite -dCompatibilityLevel=1.4 -dPDFSETTINGS=/screen -dNOPAUSE -dQUIET -dBATCH -sOutputFile="$output_folder/$filename"_"$page_range"_compressed.pdf "$output_folder/$filename"_"$page_range".pdf
# 删除未压缩的文件(可选)
rm "$output_folder/$filename"_"$page_range".pdf
done
请注意,你需要将/path/to/input/folder
替换为你的输入文件夹路径,将/path/to/output/folder
替换为你的输出文件夹路径。你还可以自定义要提取的页码范围,并选择是否压缩提取的PDF文件。
chmod +x extract_pages.sh
./extract_pages.sh
脚本将遍历输入文件夹中的所有PDF文件,并将特定页码范围的页面提取到输出文件夹中。如果选择了压缩选项,脚本还将使用Ghostscript压缩提取的PDF文件。
希望以上解决方法能够满足你的需求!