A simplified port of Python's pdf2image
that wraps pdftoppm
and pdftocairo
(part of poppler) to convert PDFs to image::DynamicImage
s.
Add to your project: cargo add pdf2image
pdf2image
requires poppler
to be installed.
Windows users will have to build or download poppler
for Windows. Python's pdf2image
maintainer recommends @oschwartz10612 version. You will then have to add the bin/
folder to PATH or use the environment variable PDF2IMAGE_POPPLER_PATH
.
using homebrew:
brew install poppler
Most distros ship with pdftoppm
and pdftocairo
. If they are not installed, refer to your package manager to install poppler-utils
- Install
poppler
:conda install -c conda-forge poppler
- Install
pdf2image
:pip install pdf2image
use pdf2image::{PDF2ImageError, RenderOptionsBuilder, PDF};
fn main() -> Result<(), PDF2ImageError> {
let pdf = PDF::from_file("examples/pdfs/ropes.pdf").unwrap();
let pages = pdf.render(
pdf2image::Pages::Range(1..=8),
RenderOptionsBuilder::default().build()?,
);
println!("{:?}", pages.unwrap().len());
Ok(())
}
- Reviewed all occurences of
.unwrap()
, refactored unnecessary ones to return errors and added comments detailing why it is safe to call (Thank you @qarmin!).
pdf2image
includes code derived from Edouard Belval's pdf2image
Python module, which is MIT licensed. Similarly, pdf2image
is also licensed under the MIT License.