Unofficial Python client for Meta Threads API
Project description
Meta's Threads.net API
Unofficial, Reverse-Engineered Python client for Meta's Threads.
Inspired by NPM Threads-API
Threads API - Python
Threads API is an unofficial Python client for Meta's Threads API. It allows you to interact with the API to retrieve user profile information, user IDs, and user profile threads.
Table of content:
Getting Started
📦 Installation
pip install threads-api
or
poetry install threads-api
Usage Examples
"get_user_id_from_username" Function
from threads_api.src.threads_api import ThreadsAPI
import asyncio
async def get_user_id_from_username():
threads_api = ThreadsAPI()
username = "zuck"
user_id = await threads_api.get_user_id_from_username(username)
if user_id:
print(f"The user ID for username '{username}' is: {user_id}")
else:
print(f"User ID not found for username '{username}'")
Example Output:
The user ID for username 'zuck' is: 314216
"get_user_profile" Function
async def get_user_profile():
threads_api = ThreadsAPI()
username = "zuck"
user_id = await threads_api.get_user_id_from_username(username)
if user_id:
user_profile = await threads_api.get_user_profile(username, user_id)
print(f"User profile for '{username}':")
print(f"Name: {user_profile['username']}")
print(f"Bio: {user_profile['biography']}")
print(f"Followers: {user_profile['follower_count']}")
else:
print(f"User ID not found for username '{username}'")
Example Output:
User profile for 'zuck':
Name: zuck
Bio:
Followers: 2288633
"get_user_profile_threads" Function
async def get_user_profile_threads():
threads_api = ThreadsAPI()
username = "zuck"
user_id = await threads_api.get_user_id_from_username(username)
if user_id:
threads = await threads_api.get_user_profile_threads(username, user_id)
print(f"The threads for user '{username}' are:")
for thread in threads:
print(f"Text: {thread['thread_items'][0]['post']['caption']} || Likes: {thread['thread_items'][0]['post']['like_count']}")
else:
print(f"User ID not found for username '{username}'")
Example Output:
The threads for user 'zuck' are:
zuck's Post: {'text': '70 million sign ups on Threads as of this morning. Way beyond our expectations.'} || Likes: 159293
zuck's Post: {'text': 'Lots of work on basic capabilities this morning.'} || Likes: 217148
zuck's Post: {'text': "Wow, 30 million sign ups as of this morning. Feels like the beginning of something special, but we've got a lot of work ahead to build out the app."} || Likes: 340098
zuck's Post: {'text': '10 million sign ups in seven hours 🤯'} || Likes: 357105
zuck's Post: {'text': 'Just passed 5 million sign ups in the first four hours...'} || Likes: 156277
zuck's Post: {'text': 'Threads just passed 2 million sign ups in the first two hours.'} || Likes: 132504
zuck's Post: {'text': "Glad you're all here on day one. Let's build something great together!"} || Likes: 175563
zuck's Post: {'text': "Let's do this. Welcome to Threads. 🔥"} || Likes: 166987
"get_user_profile_replies" Function
async def get_user_profile_replies():
threads_api = ThreadsAPI()
username = "zuck"
user_id = await threads_api.get_user_id_from_username(username)
if user_id:
threads = await threads_api.get_user_profile_replies(username, user_id)
print(f"The replies for user '{username}' are:")
for thread in threads:
print(f"-\n{thread['thread_items'][0]['post']['user']['username']}'s Post: {thread['thread_items'][0]['post']['caption']} || Likes: {thread['thread_items'][0]['post']['like_count']}")
if len(thread["thread_items"]) > 1:
print(f"{username}'s Reply: {thread['thread_items'][1]['post']['caption']} || Likes: {thread['thread_items'][1]['post']['like_count']}\n-")
else:
print(f"-> You will need to sign up / login to see more.")
else:
print(f"User ID not found for username '{username}'")
Example Output:
mosseri's Post: {'text': 'I joined Meta, then Facebook, 15 years ago today. We were four years old, had ~450 employees, had just translated the site, and had ~70M people.\n\nToday we hit that many signups on Threads. Now signups and retained users are different, and we built Threads on top of an amazing foundation provided by Instagram and by Meta, but there is something elegant about that symmetry.\n\nThank you to the team that actually built this app, thank you to the company and @zuck for trusting me all these years, 🙏🏼'} || Likes: 25523
zuck's Reply: {'text': "Congrats! Great milestone to celebrate 15 years. I'm grateful for everything you do."} || Likes: 5506
-
-
adidas's Post: {'text': 'to sock and slide or not to sock and slide today…'} || Likes: 7425
zuck's Reply: {'text': 'No socks for life'} || Likes: 9976
-
-
evachen212's Post: {'text': 'This is a good first Thread 🙌🏼'} || Likes: 8739
zuck's Reply: {'text': 'Believe when I say, I want it that way.'} || Likes: 23991
-
-
iamsamyrlaine's Post: {'text': "Can't remember the last time I even had the Twitter app on my phone, let alone posted something there; I'm definitely down with Threads though!"} || Likes: 4876
zuck's Reply: {'text': '🙌'} || Likes: 7928
...
"get_post_id_from_url" Function
async def get_post_id_from_url():
threads_api = ThreadsAPI()
post_url = "https://www.threads.net/t/CuZsgfWLyiI"
post_id = await threads_api.get_post_id_from_url(post_url)
print(f"'Thread post {post_id}':")
Example Output:
Thread post_id is 3141737961795561608
"get_post" Function
async def get_post():
threads_api = ThreadsAPI()
post_url = "https://www.threads.net/t/CuZsgfWLyiI"
post_id = await threads_api.get_post_id_from_url(post_url)
thread = await threads_api.get_post(post_id)
print(f"'Thread post {thread['containing_thread']['thread_items'][0]['post']['caption']}':")
for thread in thread["reply_threads"]:
print(f"-\n{thread['thread_items'][0]['post']['user']['username']}'s Post: {thread['thread_items'][0]['post']['caption']} || Likes: {thread['thread_items'][0]['post']['like_count']}")
Example Output:
zuck's post {'text': '70 million sign ups on Threads as of this morning. Way beyond our expectations.'}:
-
luclevesque's Reply: {'text': 'Wow 🤯'} || Likes: 167
-
jasminericegirl's Reply: {'text': 'you are doing amazing sweetie'} || Likes: 391
-
zhra.ghalenoei's Reply: {'text': 'نصفشون ایرانین یَره🤣'} || Likes: 0
-
a.llisterthomas's Reply: {'text': 'elon finna drop this guy😭🥊'} || Likes: 0
-
_vormund_'s Reply: None || Likes: 0
-
sri_ty_'s Reply: {'text': '🐸So nice'} || Likes: 0
-
_william.carrera_'s Reply: {'text': 'Where’s the porn here Mr Zuck'} || Likes: 0
-
kal_blogs's Reply: {'text': 'When you said ‘our’, was it the ‘royal our’?'} || Likes: 0
-
nasheet's Reply: {'text': 'That is crazy road to 100M'} || Likes: 19
-
dsb.don's Reply: {'text': 'You did it 🇰🇪♥️'} || Likes: 0
-
pisceansoulx's Reply: {'text': 'Wohoo. You the man Zucker'} || Likes: 0
-
winchester_757's Reply: {'text': 'If only the meta verse was this good LMAO'} || Likes: 0
-
winchester_757's Reply: {'text': 'Only 10 mil more to match the big guy'} || Likes: 0
📌 Roadmap
- ✅ Read public data\
- ✅ Fetch UserID(
314216
) via username(zuck
) - ✅ Read user profile info
- ✅ Read list of user Threads
- ✅ Read list of user Replies
- ✅ Read Post and a list of its Replies
- ✅ Fetch UserID(
- 🚧 Read private data
- 🚧 Write data (i.e. write automated Threads)
- [ ]🚧 CI/CD
- [ ]🚧 Pytest
- [ ]🚧 GitHub Actions Pipeline
License
This project is licensed under the MIT license.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
threads-api-1.0.5.tar.gz
(11.0 kB
view details)
Built Distribution
File details
Details for the file threads-api-1.0.5.tar.gz
.
File metadata
- Download URL: threads-api-1.0.5.tar.gz
- Upload date:
- Size: 11.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e620ebaca1c2720b45dfc5cf757302408b73762d9920f8f6e965f766395cd331 |
|
MD5 | 2963eeddff7a814ebf5fbba4e6b8cd1e |
|
BLAKE2b-256 | 46bb5f2e20e4858de7399eb17513e08ecf3baf69f2d8559f1b8eed4e7b5195c5 |
Provenance
File details
Details for the file threads_api-1.0.5-py3-none-any.whl
.
File metadata
- Download URL: threads_api-1.0.5-py3-none-any.whl
- Upload date:
- Size: 8.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 132a053fd55e013d0c647e1317fe966220aaf0809953aaa251974a91f20f6711 |
|
MD5 | f36123e1894458ecce961a519f96cd31 |
|
BLAKE2b-256 | 159bc958489440d6caddc141c9dfc3fd44b0ad887f06102d9147616c5cb02fd5 |