Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bisguzar/twitter-scraper
Scrape the Twitter Frontend API without authentication.
https://github.com/bisguzar/twitter-scraper
client javascript no-authentication python tweets twitter twitter-api
Last synced: 3 months ago
JSON representation
Scrape the Twitter Frontend API without authentication.
- Host: GitHub
- URL: https://github.com/bisguzar/twitter-scraper
- Owner: bisguzar
- License: mit
- Created: 2018-02-22T14:58:34.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2023-10-30T05:53:33.000Z (about 1 year ago)
- Last Synced: 2024-05-19T06:06:12.274Z (8 months ago)
- Topics: client, javascript, no-authentication, python, tweets, twitter, twitter-api
- Language: Python
- Homepage:
- Size: 232 KB
- Stars: 3,833
- Watchers: 99
- Forks: 598
- Open Issues: 57
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome - bisguzar/twitter-scraper - Scrape the Twitter Frontend API without authentication. (Python)
- stars - bisguzar/twitter-scraper - Scrape the Twitter Frontend API without authentication. (Python)
- awesome-hacking-lists - bisguzar/twitter-scraper - Scrape the Twitter Frontend API without authentication. (Python)
- awesome-technostructure - bisguzar/twitter-scraper - scraper: Scrape the Twitter Frontend API without authentication. ([✨ inspiration](https://github.com/stars/ketsapiwiq/lists/inspiration))
- awesome-technostructure - bisguzar/twitter-scraper - scraper: Scrape the Twitter Frontend API without authentication. ([✨ inspiration](https://github.com/stars/ketsapiwiq/lists/inspiration))
README
# Twitter Scraper
![GitHub](https://img.shields.io/github/license/bisguzar/twitter-scraper) ![GitHub contributors](https://img.shields.io/github/contributors/bisguzar/twitter-scraper) ![code size](https://img.shields.io/github/languages/code-size/bisguzar/twitter-scraper) ![maintain status](https://img.shields.io/maintenance/yes/2020)
[🇰🇷 Read Korean Version](https://github.com/bisguzar/twitter-scraper/blob/master/twitter_scraper/__init__.py)
Twitter's API is annoying to work with, and has lots of limitations — luckily their frontend (JavaScript) has it's own API, which I reverse–engineered. No API rate limits. No restrictions. Extremely fast.
You can use this library to get the text of any user's Tweets trivially.
## Prerequisites
Before you begin, ensure you have met the following requirements:
* Internet Connection
* Python 3.6+## Installing twitter-scraper
If you want to use latest version, install from source. To install twitter-scraper from source, follow these steps:
Linux and macOS:
```bash
git clone https://github.com/bisguzar/twitter-scraper.git
cd twitter-scraper
sudo python3 setup.py install
```Also, you can install with PyPI.
```bash
pip3 install twitter_scraper
```## Using twitter_scraper
Just import **twitter_scraper** and call functions!
### → function **get_tweets(query: str [, pages: int])** -> dictionary
You can get tweets of profile or parse tweets from hashtag, **get_tweets** takes username or hashtag on first parameter as string and how much pages you want to scan on second parameter as integer.#### Keep in mind:
* First parameter need to start with #, number sign, if you want to get tweets from hashtag.
* **pages** parameter is optional.```python
Python 3.7.3 (default, Mar 26 2019, 21:43:19)
[GCC 8.2.1 20181127] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from twitter_scraper import get_tweets
>>>
>>> for tweet in get_tweets('twitter', pages=1):
... print(tweet['text'])
...
spooky vibe check
…
```It returns a dictionary for each tweet. Keys of the dictionary;
| Key | Type | Description |
|-----------|------------|------------------------------------------------------------------|
| tweetId | string | Tweet's identifier, visit twitter.com/USERNAME/ID to view tweet. |
| userId | string | Tweet's userId |
| username | string | Tweet's username |
| tweetUrl | string | Tweet's URL |
| isRetweet | boolean | True if it is a retweet, False otherwise |
| isPinned | boolean | True if it is a pinned tweet, False otherwise |
| time | datetime | Published date of tweet |
| text | string | Content of tweet |
| replies | integer | Replies count of tweet |
| retweets | integer | Retweet count of tweet |
| likes | integer | Like count of tweet |
| entries | dictionary | Has hashtags, videos, photos, urls keys. Each one's value is list|### → function **get_trends()** -> list
You can get the Trends of your area simply by calling `get_trends()`. It will return a list of strings.```python
Python 3.7.3 (default, Mar 26 2019, 21:43:19)
[GCC 8.2.1 20181127] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from twitter_scraper import get_trends
>>> get_trends()
['#WHUTOT', '#ARSSOU', 'West Ham', '#AtalantaJuve', '#バビロニア', '#おっさんずラブinthasky', 'Southampton', 'Valverde', '#MMKGabAndMax', '#23NParoNacional']
```### → class **Profile(username: str)** -> class instance
You can get personal information of a profile, like birthday and biography if exists and public. This class takes username parameter. And returns itself. Access informations with class variables.```python
Python 3.7.3 (default, Mar 26 2019, 21:43:19)
[GCC 8.2.1 20181127] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from twitter_scraper import Profile
>>> profile = Profile('bugraisguzar')
>>> profile.location
'Istanbul'
>>> profile.name
'Buğra İşgüzar'
>>> profile.username
'bugraisguzar'
```#### → **.to_dict()** -> dict
**to_dict** is a method of *Profile* class. Returns profile datas as Python dictionary.
```python
Python 3.7.3 (default, Mar 26 2019, 21:43:19)
[GCC 8.2.1 20181127] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> from twitter_scraper import Profile
>>> profile = Profile("bugraisguzar")
>>> profile.to_dict()
{'name': 'Buğra İşgüzar', 'username': 'bugraisguzar', 'birthday': None, 'biography': 'geliştirici@peptr', 'website': 'bisguzar.com', 'profile_photo': 'https://pbs.twimg.com/profile_images/1199305322474745861/nByxOcDZ_400x400.jpg', 'banner_photo': 'https://pbs.twimg.com/profile_banners/1019138658/1555346657/1500x500', 'likes_count': 2512, 'tweets_count': 756, 'followers_count': 483, 'following_count': 255, 'is_verified': False, 'is_private': False, user_id: "1019138658"}
```## Contributing to twitter-scraper
To contribute to twitter-scraper, follow these steps:1. Fork this repository.
2. Create a branch with clear name: `git checkout -b `.
3. Make your changes and commit them: `git commit -m ''`
4. Push to the original branch: `git push origin /`
5. Create the pull request.Alternatively see the GitHub documentation on [creating a pull request](https://help.github.com/en/github/collaborating-with-issues-and-pull-requests/creating-a-pull-request).
## Contributors
Thanks to the following people who have contributed to this project:
* @kennethreitz (author)
* @bisguzar (maintainer)
* @lionking6792
* @ozanbayram
* @xeliot## Contact
If you want to contact me you can reach me at [@bugraisguzar](https://twitter.com/bugraisguzar).## License
This project uses the following license: [MIT](https://github.com/bisguzar/twitter-scraper/blob/master/LICENSE).