Skip to main content

Quick look geospatial viewer for the terminal, with inline image previews

Project description

viewinline

Downloads PyPI version Python version

Quick-look geospatial viewer for compatible terminals.
Displays rasters, vectors, and tabular data directly in the terminal with no GUI and no temporary files.

Think of it as ls for geospatial files — designed for quick visual inspection at the command line, not a replacement for QGIS, ArcGIS, or analytical workflows.

Particularly useful on HPC systems and remote servers accessed via SSH. Images render on your local terminal without X11 forwarding, VNC, or file downloads.

This tool combines the core display logic of viewtif and viewgeom, but is non-interactive: you can't zoom, pan, or switch colormaps on the fly. Instead, you control everything through command-line options (e.g. --display, --color-by, --colormap).

It uses the iTerm2 inline image protocol (OSC 1337) in supported terminals, and falls back to chafa in others, which displays real high-res images in terminals like kitty and Ghostty, and colored block-art (ASCII art) previews in Terminal.app, VS Code, and most Linux terminals. Without chafa installed, non-iTerm2-family terminals show an info message instead.

Installation

Requires Python 3.9 or later.

pip install viewinline

Usage

# Rasters
viewinline path/to/file.tif
viewinline R.tif G.tif B.tif                 # RGB composite (also works with --rgbfiles)
viewinline path/to/multiband.tif --rgb 3 2 1
viewinline path/to/folder --gallery 4x3      # show image gallery (e.g. 4x3 grid)

# NetCDF and HDF
viewinline file.nc                           # list variables
viewinline file.nc --subset 2                # display variable 2
viewinline file.nc --subset 1 --band 10      # variable 1, timestep 10 --band or --timestep
viewinline temp.nc --subset 1 --colormap plasma --vmin 273 --vmax 310

# Vectors
viewinline path/to/vector.geojson
viewinline boundaries.geoparquet --color-by population --colormap viridis

# CSV and Parquet
viewinline data.csv                          # preview rows and columns
viewinline data.parquet --describe           # summary statistics
viewinline data.csv --hist                   # histograms for all numeric columns
viewinline data.csv --hist area_km2          # histogram for one column
viewinline data.csv --scatter X Y            # scatter plot
viewinline data.csv --where "year > 2010"    # filter rows
viewinline data.csv --sort population --desc # sort rows
viewinline data.csv --sql "SELECT * FROM data WHERE area > 100 ORDER BY year"  # full SQL

# Tabular view of vectors
viewinline counties.shp --table              # view shapefile as table
viewinline counties.shp --table --describe   # summary statistics
viewinline counties.shp --table --unique STATE_NAME
viewinline data.geoparquet --table --where "POP > 100000" --sort POP --desc

Compatible terminals

Native (no extra install required): images render via the iTerm2 inline image protocol on:

  • iTerm2 (macOS)
  • WezTerm (cross-platform)
  • Konsole (Linux/KDE)
  • Rio, Contour (cross-platform)

Via chafa (recommended for everyone else): install chafa and viewinline works in nearly every terminal:

  • kitty, Ghostty, foot — real high-resolution images via the kitty graphics protocol or sixel
  • Terminal.app, VS Code, GNOME Terminal, Alacritty, Warp, Hyper — colored block-art previews with 24-bit color

Install chafa once (it's a system binary, available across all conda/virtualenv environments):

brew install chafa          # macOS
sudo apt install chafa      # Debian/Ubuntu
sudo dnf install chafa      # Fedora

Without chafa, terminals outside the native list above show an info message instead of an image. You can also force the chafa path on any terminal by setting INLINE_VIEWER_ENGINE=chafa.

SSH/HPC usage: Works over SSH when connecting from a compatible terminal. Images render on your local machine, not the remote server. No X11 forwarding or VNC required.

tmux/screen: Inline images work inside tmux only when the outer terminal is iTerm2 (or WezTerm/Konsole/Rio/Contour). In tmux with other outer terminals (kitty, Terminal.app, etc.), viewinline displays ASCII art previews instead of full-quality images.

Fallback: In terminals that do not support inline images, you can fallback to ASCII art by installing chafa command-line tool. Install chafa with your package manager (e.g. brew install chafa or sudo apt install chafa). You can also force the use of chafa by setting the environment variable INLINE_VIEWER_ENGINE=chafa.

Features

  • Previews rasters, vectors, and tabular data directly in the terminal
  • Non-interactive: everything is controlled through command-line options
  • NetCDF/HDF Support: Display variables from NetCDF (.nc) and HDF5 (.h5, .hdf5) files with automatic nodata detection and multi-slice navigation
  • Parquet/GeoParquet: Render GeoParquet as vector maps or view as tabular data
  • Tabular View for Vectors: Use --table to access CSV-style operations (filter, sort, describe, hist) on any vector file

Supported formats

Rasters

  • GeoTIFF (.tif, .tiff)
  • PNG, JPEG (.png, .jpg, .jpeg)
  • NetCDF (.nc)
  • HDF5 (.h5, .hdf5)
  • HDF4 (.hdf) — requires GDAL with HDF4 support
  • Single-band or multi-band composites

Composite inputs

  • You can pass three rasters (e.g. R.tif G.tif B.tif) or use --rgbfiles R.tif G.tif B.tif to create an RGB composite
  • Multi-band files: use --rgb 3 2 1 to specify band order

Vectors

  • GeoJSON (.geojson)
  • Shapefile (.shp)
  • GeoPackage (.gpkg)
  • Parquet/GeoParquet (.parquet, .geoparquet)

Tabular data (CSV and Parquet)

  • CSV (.csv)
  • Parquet (.parquet) — requires pyarrow
  • All CSV operations work on parquet files
  • Preview file summary (rows, columns, and names)
  • Summary statistics with --describe
  • Inline histograms with --hist
  • Scatter plots with --scatter X Y
  • Filter rows with --where, sort with --sort, limit output with --limit
  • Full SQL queries with --sql (DuckDB required) — use data as the table name

Tabular view of vectors

  • Use --table flag to view any vector file (shapefiles, GeoPackage, GeoParquet) as tabular data
  • Enables all CSV-style operations: --describe, --hist, --scatter, --unique, --where, --sort

Gallery view

  • Display all images in a folder with --gallery 4x4

NetCDF/HDF notes:

  • viewinline lists only variables that can be displayed as 2D or 3D arrays
  • Variables with additional dimensions (e.g., vertical levels) may be listed but will fail to display with a clear error message
  • For a complete variable list, use ncdump -h file.nc or viewtif

Dependencies

Core dependencies (installed automatically):

  • rasterio — raster reading (includes GDAL)
  • geopandas, pyogrio — vector reading
  • matplotlib — vector rendering
  • Pillow — image encoding
  • numpy, pandas — data handling

Optional dependencies:

  • chafa — strongly recommended for terminal coverage beyond iTerm2/WezTerm/Konsole/Rio/Contour. System binary, not a Python package. See "Terminal support" above for install instructions.
  • duckdb — required for --where, --sort, --sql, --limit with filtering
    pip install duckdb
    
  • pyarrow — required for Parquet/GeoParquet files
    pip install pyarrow
    
  • h5py — fallback for HDF5 files if GDAL lacks HDF5 support (usually not needed)
    pip install h5py
    

Note on HDF support:

  • HDF5 (.h5, .hdf5): Supported via rasterio if GDAL has HDF5 support (most installations)
  • HDF4 (.hdf): Requires GDAL compiled with HDF4 support (common in MODIS data)
  • NetCDF (.nc): Supported via rasterio (uses GDAL's NetCDF driver)

Available options

General:
  --display DISPLAY     Resize only the displayed image (0.5=smaller, 2=bigger). Default: auto-fit to terminal.

Raster:
  --band BAND           Band number to display (single raster), or slice number for NetCDF. (default: 1)
  --timestep INTEGER    Alias for --band when working with NetCDF files.
  --subset INTEGER      Variable index for NetCDF/HDF files (e.g., --subset 1).
  --colormap            Apply colormap to single-band rasters. Flag without the color scheme → 'terrain'.
  --rgb R G B           Three band numbers for RGB display (e.g., --rgb 4 3 2). Overrides default 1 2 3.
  --rgbfiles R G B      Three single-band rasters for RGB composite. Can also provide as positional arguments.
  --vmin VMIN           Minimum pixel value for raster display scaling.
  --vmax VMAX           Maximum pixel value for raster display scaling.
  --nodata NODATA       Override nodata value for rasters if dataset metadata is missing or incorrect.
  --gallery [GRID]      Display all PNG/JPG/TIF images in a folder as thumbnails (e.g., 5x5 grid).

Vector:
  --color-by COLUMN     Column to color vector features by.
  --colormap            Apply colormap to vector coloring. Flag without value → 'terrain'.
  --width WIDTH         Line width for vector boundaries. (default: 0.7)
  --edgecolor COLOR     Edge color for vector outlines (hex or named color). (default: white)
  --layer LAYER         Layer name for GeoPackage/multi-layer files, or variable name for NetCDF files.
  --table               Display vector/parquet file as tabular data instead of rendering geometry.

CSV and Parquet:
  --describe [COLUMN]   Show summary statistics for all numeric columns or specify one column name.
  --hist [COLUMN]       Show histograms for all numeric columns or specify one column name.
  --bins BINS           Number of bins for histograms (used with --hist). (default: 20)
  --scatter X Y         Plot scatter of two numeric columns (e.g., --scatter area_km2 year).
  --unique COLUMN       Show unique values for a categorical column.
  --where EXPR          Filter rows using SQL WHERE clause (DuckDB required). Example: --where "year > 2010"
  --sort COLUMN         Sort rows by column, ascending by default. Use --desc to reverse.
  --desc                Sort in descending order (used with --sort).
  --limit N             Limit number of rows shown (e.g., --limit 100).
  --select COLUMNS      Select specific columns (space separated). Example: --select Country City
  --sql QUERY           Execute full DuckDB SQL query. Use 'data' as table name. Example: --sql "SELECT * FROM data WHERE Poverty > 40"

Need help?

NASA staff can ask questions about usage via the documentation-based assistant 'viewtif + viewgeom + viewinline Helper' via the ChatGSFC Agent Marketplace.

License

This project is released under the Apache License 2.0 © 2026 Keiko Nomura.

If you find this tool useful, please consider supporting or acknowledging it in your work.

Useful links

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

viewinline-0.2.3.tar.gz (4.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

viewinline-0.2.3-py3-none-any.whl (25.5 kB view details)

Uploaded Python 3

File details

Details for the file viewinline-0.2.3.tar.gz.

File metadata

  • Download URL: viewinline-0.2.3.tar.gz
  • Upload date:
  • Size: 4.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.5

File hashes

Hashes for viewinline-0.2.3.tar.gz
Algorithm Hash digest
SHA256 c3f6718881e43e902f4944c231ca2902e7459da47a1d6f952ee1c4eee5c1b191
MD5 12176a55c1ea73fca2f6770a32d2a4a3
BLAKE2b-256 6668fc98cc266ab53fdfeff9742ad8c68a99725d76296502e728659950b2162b

See more details on using hashes here.

File details

Details for the file viewinline-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: viewinline-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 25.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.5

File hashes

Hashes for viewinline-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 62dca105b5b355ed9f4093e93400d59ba065369ef045f7a981a4065a39e120b0
MD5 9dd09601aa8a140443486dcad7563c28
BLAKE2b-256 b6fa07563466699c3ead2cef432afabff364d50dd9284239ff9e743c960412e3

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