Skip to main content

Python client for the TrustMRR API

Project description

trustmrr 🐍💸

A Python client for the TrustMRR API,
for people who like their startup data the way they like their coffee:
strong, typed, and delivered in cents.

PyPI Python License


What is this? 🤔

You want to know which startups are on sale. You want to know their MRR, their multiples, their vibes. You want it in Python. You do not want to write requests.get(...) for the seventeenth time this week.

This library does that. You're welcome.

Install 📦

pip install trustmrr

That's it. No build step. No native deps. No "first install Rust." It's 2026 and we're not animals.

60-second quickstart ⏱️

from trustmrr import TrustMRRClient

client = TrustMRRClient(api_key="tmrr_your_api_key")  # don't commit this. don't.

deals = client.list_startups(sort="best-deal", on_sale=True, limit=5)

for s in deals["data"]:
    print(f"{s['slug']:20} MRR ${s['revenue']['mrr']/100:>10,.2f}  multiple {s['multiple']}x")

Output (your numbers will vary, theirs always do):

acmehq               MRR $  35,000.00  multiple 3.2x
widgetco             MRR $  18,420.00  multiple 2.7x
...

Pagination, the lazy way 😴

You could write a while True: with a page counter and a hasMore check. Or you could not.

for startup in client.iter_startups(category="SaaS", min_mrr=100_000):
    print(startup["slug"])

iter_startups yields rows forever until the API politely says "I have no more startups for you." It will then stop. Generators: still good.

All the knobs 🎛️

Every parameter is keyword-only and optional. Set what you need, ignore the rest.

Knob Type What it does
page int Page number (≥ 1). For when you're feeling sequential.
limit int 1–50. The API draws the line at 50. We agree with the API.
sort str One of: revenue-desc, revenue-asc, price-desc, price-asc, multiple-asc, multiple-desc, growth-desc, growth-asc, listed-desc, listed-asc, best-deal.
on_sale bool True for "show me the bargain bin."
category str "SaaS", "AI", "fintech", and 20 friends.
x_handle str Founder's X/Twitter handle. Skip the @, we'll know.
min_revenue / max_revenue number Last-30-day revenue, in cents.
min_mrr / max_mrr number MRR, in cents.
min_growth / max_growth number Decimal. 0.1 = 10%. 1.0 = "are you sure?"
min_price / max_price number Asking price, in cents.

💡 Everything monetary is in cents. 42500 means $425.00. Yes, we checked. Twice. Divide by 100 before showing it to humans.

When things go sideways 💥

Non-2xx responses raise TrustMRRError. It has a .status_code and a .payload, both of which are nicer than a generic requests.HTTPError.

from trustmrr import TrustMRRError

try:
    client.list_startups()
except TrustMRRError as e:
    if e.status_code == 401:
        print("Your key is wrong, or expired, or imaginary.")
    else:
        print(f"API said {e.status_code}: {e.payload}")

Wait, where do I get an API key? 🔑

trustmrr.com. Then read the API docs for the source of truth on parameters and response shape. (This README is the friendly tour; the docs are the legal text.)

Development 🛠️

git clone https://github.com/SergeySetti/trustmrr-python.git
cd trustmrr-python
pip install -e ".[test]"
pytest

All tests are offline — HTTP is mocked, your wallet is safe.

Want to help? See CONTRIBUTING.md. PRs welcome, opinions free.

License 📜

Apache 2.0. Use it, fork it, ship it, sell it. Just don't sue us.


Made with 🐍, ☕, and a healthy distrust of un-typed JSON.

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

trustmrr-0.1.2.tar.gz (17.5 kB view details)

Uploaded Source

Built Distribution

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

trustmrr-0.1.2-py3-none-any.whl (13.2 kB view details)

Uploaded Python 3

File details

Details for the file trustmrr-0.1.2.tar.gz.

File metadata

  • Download URL: trustmrr-0.1.2.tar.gz
  • Upload date:
  • Size: 17.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for trustmrr-0.1.2.tar.gz
Algorithm Hash digest
SHA256 1442b39718b903730d1b9321a68d8a394f0322c22f054b08ef44f3fdfa65aec7
MD5 0345bd11d0a5ee3170cbbcb057e79021
BLAKE2b-256 940dc867538555a0884b980e038c27de90a0debc0158e36911d82a6649115f0e

See more details on using hashes here.

Provenance

The following attestation bundles were made for trustmrr-0.1.2.tar.gz:

Publisher: publish.yml on SergeySetti/trustmrr-python

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

File details

Details for the file trustmrr-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: trustmrr-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 13.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for trustmrr-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 2892ef23d620e8cdd0c390a4cb24b27a95232d7d88b58ea35a55f28f67392220
MD5 e5dd86998d68df10802b902bc85c38ae
BLAKE2b-256 1604d9efd4baea8e6488f5d26263a361c386138ec80a498635207252632eb2ab

See more details on using hashes here.

Provenance

The following attestation bundles were made for trustmrr-0.1.2-py3-none-any.whl:

Publisher: publish.yml on SergeySetti/trustmrr-python

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