Skip to main content

Star charts and maps of the sky

Project description

Starplot

Python PyPI License GitHub Workflow Status

Starplot is a Python library for creating star charts and maps of the sky

  • 🗺️ Maps - including 10+ customizable projections
  • Zenith Charts - shows the entire sky at a specific time and place
  • 🌃 Horizon Charts - shows the horizon at a specific time and place
  • 🔭 Optic Simulations - shows what you'll see through an optic (e.g. telescope) at a specific time and place
  • 🪐 Planets and Deep Sky Objects (DSOs) - with support for plotting their true extent
  • ☄️ Comets and Satellites - easy trajectory plotting
  • 🎨 Custom Styles - for all objects and with 8+ built-in themes
  • 📥 Export - png, svg, jpeg
  • 🚀 Data Backend - powered by DuckDB + Ibis for fast object lookup
  • 📓 Custom Data Catalogs - with helpers for building and optimizing
  • 🧭 Label Collision Avoidance - ensuring all labels are readable
  • 🌐 Localization - label translations for Chinese, French, Lithuanian, Persian, and Spanish

Examples

Zenith chart of the stars from a specific time/location: starchart-blue

Map around the constellation Orion: map-orion

The Pleiades star cluster, as seen through a refractor telescope from a specific time and location: optic-pleiades

Basic Usage

To create a star chart for tonight's sky as seen from Palomar Mountain in California:

from datetime import datetime
from zoneinfo import ZoneInfo

from starplot import ZenithPlot, Observer, styles, _

tz = ZoneInfo("America/Los_Angeles")
dt = datetime.now(tz).replace(hour=22)

observer = Observer(
    dt=dt,
    lat=33.363484,
    lon=-116.836394,
)

p = ZenithPlot(
    observer=observer,
    style=styles.PlotStyle().extend(
        styles.extensions.BLUE_MEDIUM,
    ),
    resolution=4096,
    autoscale=True,
)
p.constellations()
p.stars(where=[_.magnitude < 4.6])
p.constellation_labels()
p.horizon()
p.export("starchart.png")

Documentation

https://starplot.dev

Demo

For a demo of Starplot's zenith charts, check out:

Sky Atlas - Star Chart Creator

Getting Help / Updates

Contributing

Contributing to Starplot is welcome and very much appreciated! Please see here for details.

Coming Soon

  • 🧮 Coordinate system helpers
  • 🌑 Planet moons
  • ✴️ Custom markers
  • 😄 🔭 Clear skies

See more details on the Public Roadmap

Related Repositories

License

MIT License

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

starplot-0.19.6.tar.gz (3.7 MB view details)

Uploaded Source

Built Distribution

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

starplot-0.19.6-py2.py3-none-any.whl (2.5 MB view details)

Uploaded Python 2Python 3

File details

Details for the file starplot-0.19.6.tar.gz.

File metadata

  • Download URL: starplot-0.19.6.tar.gz
  • Upload date:
  • Size: 3.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.31.0

File hashes

Hashes for starplot-0.19.6.tar.gz
Algorithm Hash digest
SHA256 2acb2a64643f294d2bd2953408fd783047d0307fab2058ca6c2c80d96bb1339a
MD5 24673894a5dd75a0ec38fb318d4bea93
BLAKE2b-256 e5ed2442cc58a4141948da695a48d3edf21f6f527a3094a8e016403682e29df5

See more details on using hashes here.

File details

Details for the file starplot-0.19.6-py2.py3-none-any.whl.

File metadata

  • Download URL: starplot-0.19.6-py2.py3-none-any.whl
  • Upload date:
  • Size: 2.5 MB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.31.0

File hashes

Hashes for starplot-0.19.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 0a1e1a3e42891485b6aba8b06737564b304d95e63fae156f34cd86392f5b0098
MD5 7d41a33d0cf66e90549635b31cf553ff
BLAKE2b-256 8e6a90eb57f251f098fe2ec780fa877b318a2b0b1717c65163a0fa96545e5d28

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