Skip to main content

Interactive TUI for browsing and exporting Nordnet financial data

Project description

nordpy

nordpy

A terminal UI for browsing and exporting your Nordnet portfolio data.

Python versions prek uv Ruff ty tox Pydantic Pydantic


[!CAUTION] Disclaimer – This tool is provided as-is, with no warranty of any kind. Use it at your own risk.

This project is not affiliated in any way with Nordnet nor MitID.

The author assumes no liability for any loss, damage, or misuse arising from the use of this software. You are solely responsible for securing any exported data and ensuring it is only accessible to you.

Features

  • Browse accounts, balances, holdings, transactions, trades, and orders
  • Portfolio value chart and instrument price charts in the terminal
  • Sparkline trends on holdings (3-month price history via yfinance)
  • Export data to CSV, Excel, or DuckDB
  • Session persistence with automatic re-authentication
  • Headless export mode (no TUI) for scripting
  • SOCKS5 proxy support

How It Works

nordpy authenticates with Nordnet through the same MitID flow your browser uses – it simply performs the login via Nordnet's API directly from the terminal, rather than through a web page. Once authenticated, it fetches your portfolio data using Nordnet's standard API endpoints.

[!IMPORTANT] Privacy – nordpy does not collect, transmit, or store any of your personal information. Your credentials are sent directly to MitID and Nordnet – never to any third-party server. Session cookies are saved locally on your machine (with 0600 permissions) solely to avoid repeated logins. No telemetry, analytics, or external services are involved.

Requirements

  • Python 3.10–3.13
  • A Nordnet account with MitID (Danish)

Installation

With uv

uv add nordpy

With pip

pip install nordpy

Usage

Interactive TUI

nordpy --user <your-mitid-username>

# Force re-authentication (ignore saved session)
nordpy --user <your-mitid-username> --force-login

# Verbose logging (debug output to stderr + nordpy.log)
nordpy --user <your-mitid-username> --verbose

# Delete saved session and exit
nordpy --logout

[!NOTE] The first time you log in, you may be prompted to enter your CPR number as part of the MitID verification process. This is a one-time step required by MitID to link your identity – subsequent logins will skip this.

Headless Export

nordpy --user <your-mitid-username> --export csv
nordpy --user <your-mitid-username> --export xlsx
nordpy --user <your-mitid-username> --export duckdb

# Export to a specific folder
nordpy --user <your-mitid-username> --export csv --output-dir ~/my-exports

Exported files are saved to the exports/ directory.

[!WARNING] Exported files contain sensitive financial data. Make sure you do not share these filesnor commit them to version control. Keep your exports in a secure location accessible only to you.

Keybindings

Key Action
Enter Select account / view instrument chart
Tab Switch between tabs
e Export current view
r Refresh data
Backspace / Esc Go back / quit
q Quit

Development

git clone https://github.com/kiliantscherny/nordpy.git
cd nordpy
uv sync --dev

Running checks

# Run all checks (tests on Python 3.10–3.13, lint, type check)
uv run tox

# Run tests only
uv run pytest

# Run tests with coverage
uv run pytest --cov=nordpy --cov-report=term-missing

# Lint
uv run ruff check .

# Type check
uv run ty check

License

This project is licensed under the MIT License.

Acknowledgments

This project includes code from MitID-BrowserClient by Hundter, licensed under the MIT License.

Credit also to Morten Helmstedt for the groundwork of looking into this.

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

nordpy-1.0.1.tar.gz (50.0 kB view details)

Uploaded Source

Built Distribution

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

nordpy-1.0.1-py3-none-any.whl (64.1 kB view details)

Uploaded Python 3

File details

Details for the file nordpy-1.0.1.tar.gz.

File metadata

  • Download URL: nordpy-1.0.1.tar.gz
  • Upload date:
  • Size: 50.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for nordpy-1.0.1.tar.gz
Algorithm Hash digest
SHA256 da11a7ab5aad34746ba57d727c53950f982284c4edcc53d57c2695d9d806d012
MD5 c6bb5464503598617681a78a1b65b08f
BLAKE2b-256 abe77c4654b7e06afb5597f2924833b055e9fec16e2acfdd8bcb7051fa693dfb

See more details on using hashes here.

Provenance

The following attestation bundles were made for nordpy-1.0.1.tar.gz:

Publisher: release.yml on kiliantscherny/nordpy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file nordpy-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: nordpy-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 64.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for nordpy-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 db5afe552fddc276484feab8dec1044a9aba6d6e4f2dac406b02797396b32658
MD5 29f0817e36341a28d848c21fd94afc8a
BLAKE2b-256 45d93045709c4df40cef98b0a97cd2457f78ebe5beb06dd070cfd06eec841b37

See more details on using hashes here.

Provenance

The following attestation bundles were made for nordpy-1.0.1-py3-none-any.whl:

Publisher: release.yml on kiliantscherny/nordpy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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