Scrape Twitter API without authentication using Nitter.
Project description
Nitter Scraper
This library is a work around for anyone who enjoyed the simplicity of the twitter-scraper library and needs a quick replacement until it comes back up. Nitter Scraper leverages running a docker instance of nitter to scrape tweets and profile information. I attempted to make the api work as closely as possible to the original to minimize refactoring of other projects.
Use Nitter Scraper with docker
If you have docker installed you can use the NitterDockerContainer manager. It takes care of starting/stoping a local nitter docker container and provides the address to scrape from. If you don't use the NitterDockerContainer the get_tweets and get_profile methods will resolve to scraping from https://nitter.net
from nitter_scraper import NitterDockerContainer, get_tweets
with NitterDockerContainer(host="0.0.0.0", port=8008) as nitter:
for tweet in get_tweets("dgnsrekt", address=nitter.address):
print(tweet.json(indent=4))
Prerequisites
- Docker
- Python ^3.7
Run the examples.
git clone git@github.com:dgnsrekt/nitter_scraper.git
cd nitter_scraper
poetry install
poetry shell
Add twitter usernames to the example.txt delimited by newlines.
Docker must be properly installed to run the examples with the NitterDockerContainer context manager.
Run profile scraping example
python3 example_profile.py
Run tweet scraping example
python3 example_tweet.py
Profile & Tweet objects
The Profile and Tweet classes inherit from pydantic's BaseModel. This makes it easy to convert to a dict or json.
profile = get_profile("dgnsrekt")
profile.json(indent=4)
profile.dict()
Profile Schema
These are the fields uses in the Profile class which is returned from the get_profile() method.
{
"title": "Profile",
"type": "object",
"properties": {
"username": {
"title": "Username",
"type": "string"
},
"name": {
"title": "Name",
"type": "string"
},
"profile_photo": {
"title": "Profile Photo",
"type": "string"
},
"tweets_count": {
"title": "Tweets Count",
"type": "integer"
},
"following_count": {
"title": "Following Count",
"type": "integer"
},
"followers_count": {
"title": "Followers Count",
"type": "integer"
},
"likes_count": {
"title": "Likes Count",
"type": "integer"
},
"is_verified": {
"title": "Is Verified",
"type": "boolean"
},
"banner_photo": {
"title": "Banner Photo",
"type": "string"
},
"biography": {
"title": "Biography",
"type": "string"
},
"user_id": {
"title": "User Id",
"type": "integer"
},
"location": {
"title": "Location",
"type": "string"
},
"website": {
"title": "Website",
"type": "string"
}
},
"required": [
"username",
"name",
"profile_photo",
"tweets_count",
"following_count",
"followers_count",
"likes_count",
"is_verified"
]
}
Tweet Schema
These are the fields uses in the Tweet class which is returned from the get_tweets() method.
{
"title": "Tweet",
"type": "object",
"properties": {
"tweet_id": {
"title": "Tweet Id",
"type": "integer"
},
"tweet_url": {
"title": "Tweet Url",
"type": "string"
},
"username": {
"title": "Username",
"type": "string"
},
"is_retweet": {
"title": "Is Retweet",
"type": "boolean"
},
"is_pinned": {
"title": "Is Pinned",
"type": "boolean"
},
"time": {
"title": "Time",
"type": "string",
"format": "date-time"
},
"text": {
"title": "Text",
"type": "string"
},
"replies": {
"title": "Replies",
"type": "integer"
},
"retweets": {
"title": "Retweets",
"type": "integer"
},
"likes": {
"title": "Likes",
"type": "integer"
},
"entries": {
"$ref": "#/definitions/Entries"
}
},
"required": [
"tweet_id",
"tweet_url",
"username",
"is_retweet",
"is_pinned",
"time",
"text",
"replies",
"retweets",
"likes",
"entries"
],
"definitions": {
"Entries": {
"title": "Entries",
"type": "object",
"properties": {
"hashtags": {
"title": "Hashtags",
"type": "array",
"items": {
"type": "string"
}
},
"cashtags": {
"title": "Cashtags",
"type": "array",
"items": {
"type": "string"
}
},
"urls": {
"title": "Urls",
"type": "array",
"items": {
"type": "string"
}
},
"photos": {
"title": "Photos",
"type": "array",
"items": {
"type": "string"
}
},
"videos": {
"title": "Videos",
"type": "array",
"items": {
"type": "string"
}
}
},
"required": [
"hashtags",
"cashtags",
"urls",
"photos",
"videos"
]
}
}
}
Limitation
- So far i've been able to pull about 800 tweets per user without issue.
- Unable to implement a way to scrape trends.
- birthday and is_private are not implemented in the profile.
- If the user does not have a banner the user_id cannot be scraped.
- The user_id cannot be scraped from tweets.
More docs coming soon.
TODO
- setup.py
- pypi
Contact Information
Telegram = Twitter = Tradingview = Discord = @dgnsrekt
Email = dgnsrekt@pm.me
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
Built Distribution
File details
Details for the file nitter_scraper-0.3.3.tar.gz
.
File metadata
- Download URL: nitter_scraper-0.3.3.tar.gz
- Upload date:
- Size: 10.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.0.10 CPython/3.8.2 Linux/5.4.0-7634-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2ea2e0a8fa2d8525f0ee6fd4f17d5d6d0209ff55601fea449f4defe2058531f5 |
|
MD5 | 321c1420b4b178c864e48374027e2c3d |
|
BLAKE2b-256 | 0c732389f41828e63061d2855b9e3c246aea7263ef65e328a4db680a012263e2 |
File details
Details for the file nitter_scraper-0.3.3-py3-none-any.whl
.
File metadata
- Download URL: nitter_scraper-0.3.3-py3-none-any.whl
- Upload date:
- Size: 9.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.0.10 CPython/3.8.2 Linux/5.4.0-7634-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e395853655ac6b1543a7b261e4c16615d07849aad791827344982cc5c43983ec |
|
MD5 | ac071c245c0da89a6dafa2b9b1f1763f |
|
BLAKE2b-256 | e0b4f85eca9e9bf6d1011a88211b79e303978817c6f329ea21f5ba3760280bcc |