Bash - 提取文件夹/文件夹中所有PDF的特定页
创始人
2024-11-25 11:30:33
0

要提取文件夹或文件夹中所有PDF的特定页,你可以使用Bash脚本配合使用pdftk工具和Ghostscript工具来实现。下面是一个解决方法,其中包含代码示例:

  1. 首先,确保你已经安装了pdftk和Ghostscript。你可以使用以下命令检查它们是否已安装:
pdftk --version
gs --version

如果它们没有安装,请根据你的操作系统安装它们。

  1. 创建一个Bash脚本文件,比如extract_pages.sh,并将以下代码粘贴到文件中:
#!/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文件。

  1. 保存并关闭脚本文件。然后,给予脚本执行权限,使用以下命令:
chmod +x extract_pages.sh
  1. 运行脚本,使用以下命令:
./extract_pages.sh

脚本将遍历输入文件夹中的所有PDF文件,并将特定页码范围的页面提取到输出文件夹中。如果选择了压缩选项,脚本还将使用Ghostscript压缩提取的PDF文件。

希望以上解决方法能够满足你的需求!

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...