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.8.tar.gz (17.9 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.8-py3-none-any.whl (13.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: trustmrr-0.1.8.tar.gz
  • Upload date:
  • Size: 17.9 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.8.tar.gz
Algorithm Hash digest
SHA256 ad7e57f28f72c041c5f03954bc2d9276c31779af6b383f2b475492a6b88a0547
MD5 d5706eb8e5774f135d3844fd3d290819
BLAKE2b-256 f380ac2b3bd063195fc36681d6ad58d49a8c8244c520912d683a27ac1fe7ae69

See more details on using hashes here.

Provenance

The following attestation bundles were made for trustmrr-0.1.8.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.8-py3-none-any.whl.

File metadata

  • Download URL: trustmrr-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 13.4 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.8-py3-none-any.whl
Algorithm Hash digest
SHA256 9eb77f49b4c32cc4f26705c64767be6e819bf75a5b95c6ce91148b03456e05a3
MD5 d34c62b23b63794e7f8fe955ec216154
BLAKE2b-256 8bc051792e1c582792c8622d410466946c1cb5a27cea0476cc82b03c6524707f

See more details on using hashes here.

Provenance

The following attestation bundles were made for trustmrr-0.1.8-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