Skip to main content

Read and write Netpbm files

Project description

Netpbmfile is a Python library to read and write image files in the Netpbm format as specified at http://netpbm.sourceforge.net/doc/

The following Netpbm and related formats are supported:

  • PBM (Portable Bit Map): P1 (text) and P4 (binary)

  • PGM (Portable Gray Map): P2 (text) and P5 (binary)

  • PPM (Portable Pixel Map): P3 (text) and P6 (binary)

  • PNM (Portable Any Map): shorthand for PBM, PGM, and PPM collectively

  • PAM (Portable Arbitrary Map): P7, bilevel, gray, and rgb

  • PFM (Portable Float Map): Pf (gray), PF (rgb), and PF4 (rgba), read-only

  • PGX (Portable Graymap Signed): PG, signed grayscale, read-only

  • XV thumbnail: P7 332 (rgb332), read-only

No gamma correction is performed.

The PGX format is specified in ITU-T Rec. T.803.

Author:

Christoph Gohlke

License:

BSD 3-Clause

Version:

2022.10.25

Quickstart

Install the netpbmfile package and all dependencies from the Python Package Index:

python -m pip install -U netpbmfile[all]

View image and metadata stored in a Netpbm file:

python -m oiffile file.ppm

See Examples for using the programming interface.

Source code and support are available on GitHub.

Requirements

This release has been tested with the following requirements and dependencies (other versions may work):

Revisions

2022.10.25

  • Read multi-image files.

  • Fix reading ASCII formats with trailing comments.

  • Fix writing maxval=1, depth=1 binary images.

  • Use tifffile.imshow for multi-image arrays if installed.

  • Change tupltypes to bytes according to specification (breaking).

2022.9.12

  • Allow space after token value in PAM.

  • Update metadata.

2022.2.2

  • Add type hints.

  • Support reading PF4 RGBA FloatMaps.

  • Drop support for Python 3.7 and numpy < 1.19 (NEP29).

2021.6.6

  • Fix unclosed file warnings.

  • Support reading PGX JPEG2000 reference images.

2020.10.18

  • Disallow comments after last value in PNM headers.

2020.9.18

  • Remove support for Python 3.6 (NEP 29).

  • Support os.PathLike file names.

2020.1.1

  • Fix reading tightly packed P1 format and ASCII data with inline comments.

  • Remove support for Python 2.7 and 3.5.

  • Update copyright.

2018.10.18

  • Move netpbmfile.py into netpbmfile package.

2018.02.18

  • Support reading Portable FloatMaps.

  • Style fixes.

2016.02.24

  • Use fromdata classmethod to initialize from data.

  • Support with statement.

  • Scale RGB images to maxval for display.

  • Make keyword arguments explicit.

  • Support numpy 1.10.

Examples

Save a numpy array to a Netpbm file in grayscale format:

>>> data = numpy.array([[0, 1], [65534, 65535]], dtype=numpy.uint16)
>>> imwrite('_tmp.pgm', data)

Read the image data from a Netpbm file as numpy array:

>>> image = imread('_tmp.pgm')
>>> numpy.testing.assert_equal(image, data)

Access meta and image data in a Netpbm file:

>>> with NetpbmFile('_tmp.pgm') as pgm:
...     pgm.axes
...     pgm.shape
...     pgm.dtype
...     pgm.maxval
...     pgm.magicnum
...     image = pgm.asarray()
'YX'
(2, 2)
dtype('>u2')
65535
b'P5'

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

netpbmfile-2022.10.25.tar.gz (10.0 kB view hashes)

Uploaded Source

Built Distribution

netpbmfile-2022.10.25-py3-none-any.whl (12.0 kB view hashes)

Uploaded Python 3

Supported by

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