Skip to main content

CLI for astroquery modules with autocompletion and multi-language support.

Project description

Astro CLI ๐Ÿš€

English | ไธญๆ–‡ | ๆ—ฅๆœฌ่ชž | Franรงais

Your gateway to cosmos โ€” Query astronomical data from command line

License Python Astropy npm version


โœจ What is Astro CLI?

Astro CLI is a modern command-line tool that provides quick access to multiple astronomical data services. It integrates Astroquery and other data access methods (direct API calls, HTTP requests) to help astronomers, researchers, and anyone query astronomical databases efficiently from the terminal.

17 data sources. One command. Beautiful output. Multi-language support. Extensible for future services.


๐Ÿงฉ Supported Data Sources

Query data from 17 different astronomical databases and services:

Service Description Command Alias
SIMBAD Basic astronomical data & object identification astrocli simbad astrocli sim
VizieR Catalog database search astrocli vizier astrocli viz
ALMA ALMA radio telescope observations astrocli alma -
ESASky Sky region visualization astrocli esasky -
Gaia ESA Gaia mission data astrocli gaia -
IRSA Infrared Science Archive astrocli irsa -
HEASARC X-ray and Gamma-ray data astrocli heasarc astrocli hea
JPL Horizons Solar System ephemerides astrocli jpl -
MAST Space Telescope Archive (HST, JWST, etc.) astrocli mast -
ADS Astrophysics literature search astrocli ads -
NED Extragalactic Database astrocli ned -
NIST Atomic spectra database astrocli nist -
NASA Exoplanet Exoplanet catalog astrocli exoplanet astrocli exo
SDSS Sloan Digital Sky Survey astrocli sdss -
ESO European Southern Observatory astrocli eso -
Splatalogue Molecular line database astrocli splatalogue astrocli spl
AAVSO VSX Variable Star Index astrocli aavso astrocli aav
Fermi-LAT Gamma-ray telescope data astrocli fermi astrocli fer

๐ŸŒŸ Key Features

  • ๐Ÿ“ฆ Multi-Source Access: Query 17+ astronomical databases from a single interface
  • ๐ŸŒ Internationalized UI: Built-in support for English, Chinese (Simplified), and Japanese
  • ๐Ÿ“Š Rich Output: Beautifully formatted tables with support for exporting to CSV, ECSV, FITS, and more
  • โšก Smart Defaults: Sensible defaults with extensive customization options
  • ๐Ÿ” Service Health: Built-in connectivity testing (--ping) and field validation (--field)
  • ๐Ÿง‘โ€๐Ÿ’ป Shell Completion: Auto-completion support for Bash, Zsh, and Fish
  • ๐ŸŒŒ Extensible: Easy to add new astronomical data services

๐Ÿ“ฆ Installation

Astro CLI offers multiple installation methods. Choose the one that suits you:

Method 1: npm Global Install (Recommended)

# Global install (requires Node.js โ‰ฅ18 and Python 3.11+)
npm install -g astroquery-cli

# After installation, all three commands are available:
astroquery-cli --help    # Full command name
aqc --help               # Short command (recommended)
astrocli --help          # Alias command

# Example: Query SIMBAD for M31
astrocli simbad object "M31"

Method 2: npx/pnpm (No Install Required)

# Using npx (no installation needed)
npx astroquery-cli --help

# Using pnpm
pnpm astroquery-cli --help

# Example
npx astroquery-cli simbad object "M31"

Method 3: PyPI Install (For Python Users)

# Install Python package from PyPI
pip install aqc-cli

# After installation, available commands:
aqc --help
astrocli --help

Method 4: Install from Source

git clone https://github.com/inoribea/astroquery-cli.git
cd astroquery-cli
pip install -e .

๐Ÿ“‹ Package Naming

Platform Package Name Install Command
npm astroquery-cli npm install -g astroquery-cli
PyPI aqc-cli pip install aqc-cli

After installation, all three commands are available:

  • astroquery-cli - Full command name
  • aqc - Short command (recommended)
  • astrocli - Alias command

Environment Variables

  • AC_PYTHON - Specify Python interpreter path
  • AC_VENV_DIR - Custom virtual environment cache directory (default: ~/.cache/astrocli)
  • AC_FORCE_INSTALL=1 - Force reinstall/upgrade Python dependencies
  • AC_DEBUG - Enable debug mode
  • AC_LANG - Set default language (en/zh/ja)

๐Ÿ“š Usage

View All Available Commands

# Show all available modules and commands
astrocli --help

# Show help for a specific module
astrocli <module> --help

Query Examples

1. Query SIMBAD for an object

astrocli simbad object "M31"
astrocli simbad object "Crab Nebula" --show-all-cols

2. Search VizieR catalogs

# Find catalogs by keywords
astrocli vizier find-catalogs --keyword photometry --keyword galaxy

# Query a specific catalog
astrocli vizier object "M31" --radius 0.1 --catalog "I/261/gaiadr3"

3. Query AAVSO Variable Star Index (NEW!)

# Query a variable star by name
astrocli aavso object "SS Cyg"

# Search variable stars in a sky region
astrocli aavso region 196.421 18.018 --radius 0.5

# Get results in JSON format
astrocli aavso object "T CrB" --format json

4. Query Fermi-LAT Data (NEW!)

# Query Fermi data for a target
astrocli fermi object "Crab Nebula" --energy "1000,100000" --dates "2020-01-01 00:00:00, 2020-01-02 00:00:00"

# Clear Fermi cache
astrocli fermi clear-cache

5. Search ADS literature

astrocli ads search --title "exoplanet detection"
astrocli ads bibcode "2023A&A...555..959W"

๐ŸŒ Multi-Language Support

Change output language on-the-fly:

astrocli --lang en simbad object "M31"    # English
astrocli --lang zh simbad object "M31"    # Chinese (Simplified)
astrocli --lang ja simbad object "M31"    # Japanese
astrocli --lang fr simbad object "M31"    # French

Supported languages: English (en), Chinese (zh), Japanese (ja), French (fr)


๐Ÿ”ง Global Options

Option Description
-l, --lang Set output language (en/zh/ja)
-p, --ping Test connectivity to all services (top-level only)
-f, --field Check available fields for a module (top-level only)
-d, --debug Enable debug mode with verbose output
-v, --verbose Enable verbose output

๐Ÿง‘โ€๐Ÿ’ป Shell Autocompletion

Install completion for your shell:

astrocli --install-completion bash   # Bash
astrocli --install-completion zsh    # Zsh
astrocli --install-completion fish   # Fish

Add this to your shell config (e.g., ~/.zshrc):

# For zsh
eval "$(astrocli --install-completion zsh)"

# For bash
eval "$(astrocli --install-completion bash)"

๐Ÿ“Š Output & Export

Save query results to file:

astrocli simbad object "M31" --output-file results.csv

# Specify format explicitly
astrocli simbad object "M31" --output-file data.ecsv --output-format ecsv

Supported formats: csv, ecsv, fits, votable, html, latex, ascii


๐Ÿ” Testing Service Connectivity

Check if all data services are accessible:

astrocli --ping

๐Ÿ› ๏ธ Development

Project Structure

astrocli/
โ”œโ”€โ”€ src/                    # Source code (renamed from astroquery_cli)
โ”‚   โ”œโ”€โ”€ modules/           # Service-specific modules
โ”‚   โ”‚   โ”œโ”€โ”€ simbad_cli.py
โ”‚   โ”‚   โ”œโ”€โ”€ vizier_cli.py
โ”‚   โ”‚   โ”œโ”€โ”€ aavso_cli.py      # AAVSO VSX
โ”‚   โ”‚   โ”œโ”€โ”€ fermi_cli.py      # Fermi-LAT
โ”‚   โ”‚   โ””โ”€โ”€ ...
โ”‚   โ”œโ”€โ”€ utils.py            # Common utilities
โ”‚   โ”œโ”€โ”€ common_options.py   # Shared CLI options
โ”‚   โ”œโ”€โ”€ i18n.py            # Internationalization
โ”‚   โ””โ”€โ”€ main.py            # CLI entry point
โ”œโ”€โ”€ locales/                # Translation files
โ”‚   โ”œโ”€โ”€ en/LC_MESSAGES/     # English
โ”‚   โ”œโ”€โ”€ zh/LC_MESSAGES/     # Chinese
โ”‚   โ”œโ”€โ”€ ja/LC_MESSAGES/     # Japanese
โ”‚   โ””โ”€โ”€ fr/LC_MESSAGES/     # French
โ”œโ”€โ”€ package.json           # npm/npx configuration
โ”œโ”€โ”€ pyproject.toml         # Python package config
โ””โ”€โ”€ README.md

Adding a New Module

  1. Create modules/<service>_cli.py following existing patterns
  2. Import in main.py's setup_subcommands()
  3. Add to README module list
  4. Add translations to locales/ directories

๐Ÿ“„ License

BSD 3-Clause License


๐Ÿ™ Acknowledgments

  • aqc-mcp - MCP server for AI assistants
  • Astroquery - Astronomical data access library
  • Typer - Modern CLI framework
  • Rich - Beautiful terminal output
  • AAVSO - American Association of Variable Star Observers
  • Fermi Team - Fermi Gamma-ray Space Telescope

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

inoribea_astrocli-1.4.7.tar.gz (215.8 kB view details)

Uploaded Source

Built Distribution

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

inoribea_astrocli-1.4.7-py3-none-any.whl (167.9 kB view details)

Uploaded Python 3

File details

Details for the file inoribea_astrocli-1.4.7.tar.gz.

File metadata

  • Download URL: inoribea_astrocli-1.4.7.tar.gz
  • Upload date:
  • Size: 215.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.3

File hashes

Hashes for inoribea_astrocli-1.4.7.tar.gz
Algorithm Hash digest
SHA256 5860fa42c91bd34e7bd251f03d25980a25680f15a0f1f01a710300f2fa1fad89
MD5 ea2bdb8fc7a99e0ac5e7cb79cf6ffe37
BLAKE2b-256 a7584cea76e2caefa049f795990c26bb661718f9b6fe5f58b54ddfa426b5ea24

See more details on using hashes here.

File details

Details for the file inoribea_astrocli-1.4.7-py3-none-any.whl.

File metadata

File hashes

Hashes for inoribea_astrocli-1.4.7-py3-none-any.whl
Algorithm Hash digest
SHA256 ebb4c256bef0a0aac5c97785d11212657f94e704972a7049b88a22dcbf41aab0
MD5 0c21722a932c91859116b29569dc3c5b
BLAKE2b-256 1f6eb2ea38d08894d86c6ef3635a880ed8c5bb9e0748cbc74fd737930518bc46

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