Skip to main content

Utility to use SANE/scanadf to scan to PDF

Project description

http://badge.fury.io/py/scanpdf.png http://pypip.in/d/scanpdf/badge.png

If you’re looking for a simple way to use a multi-page scanner and get your document into a PDF in Linux without any proprietary or commercial software, then ScanPDF might be the solution. I wrote it to quickly take the Linux SANE scanner system output image files, and process them into usable PDFs. By usable, I mean PDFs that maintain their original scanned resolution, omit blank pages (if you’re scanning in duplex mode, for example), preserve color unless the original is greyscale/black and white, in which case they are intelligently down-converted to B/W PDFs to save space.

Features

  • Uses SANE/scanadf to automatically scan to multi-page compressed PDFs

  • Integrates with ScanBd to respond to hardware button presses

  • Automatically removes blank pages.

  • Scans in color, and automatically down-converts into 1-bit B/W image for text/greyscale images

Usage:

The simplest way to use this is:

scanpdf scan pdf <pdffile>

This will first perform the scan, and then the conversion to PDF. If you want to split up the scan and the PDF conversion into two separate invocations (for reasons clarified below), then you can do:

scanpdf --tmpdir=tmp scan
scanpdf --tmpdir=tmp pdf <pdffile>

One reason for the separation might be if you want to keep scanning documents (very quick) while the post-processing (slower) for the PDF conversion is taking place in the background. For instance, if you’re using the hardware button on the scanner to initiate scans (as detailed in this document), then you want to return immediately after the scan instead of waiting for the full conversion to PDF has taken place.

You can optionally use the following switches to control if you’re putting pages face up or face down in the auto document feeder, if you want to skip the blank page processing, adjust the blank page detection threshold, or add additional post-processing using unpaper:

--dpi=<dpi>                 DPI to scan in [default: 300]
--face-up=<true/false>      Face-up scanning [default: True]
--keep-blanks               Don't check for and remove blank pages
--blank-threshold=<ths>     Percentage of white to be marked as blank [default: 0.97]
--post-process              Run unpaper to deskew/clean up

Right now, I’m assuming this is getting called via ScanBD, so I don’t have the option to manually specify the scanner. If you really want to use this standalone, for now, please just set the SCANBD_DEVICE environment variable to your scanner device name before running this script.

Installation

$ pip install scanpdf

Requires ImageMagick and SANE to be installed, for the command line tools:

  • convert

  • identify

  • ps2pdf

  • scanadf

Disclaimer

The software is distributed on an “AS IS” BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

scanpdf-0.2.0.tar.gz (12.8 kB view details)

Uploaded Source

File details

Details for the file scanpdf-0.2.0.tar.gz.

File metadata

  • Download URL: scanpdf-0.2.0.tar.gz
  • Upload date:
  • Size: 12.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for scanpdf-0.2.0.tar.gz
Algorithm Hash digest
SHA256 70489a802d8575edfdf23b66395bd41a8ad4a6e4c9d6b18def9f6d375a351156
MD5 2c1a0dcaa9db8017fbdc75c58364db66
BLAKE2b-256 981fd3e32dc44785ba1c531d1d19233ea9376e57f703a7461f020c16ef7a4e89

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page