Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/atharva-naik/social_media
A library for automating several social media actions, such as posting, login, notifications etc. for multiple social media sites and an API free, purely selenium based solution for scraping data without using any APIs.
https://github.com/atharva-naik/social_media
selenium-python social-media twitter youtube
Last synced: 25 days ago
JSON representation
A library for automating several social media actions, such as posting, login, notifications etc. for multiple social media sites and an API free, purely selenium based solution for scraping data without using any APIs.
- Host: GitHub
- URL: https://github.com/atharva-naik/social_media
- Owner: atharva-naik
- License: bsd-3-clause
- Created: 2020-12-12T13:41:01.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2021-10-14T18:25:16.000Z (about 3 years ago)
- Last Synced: 2023-03-06T06:11:06.834Z (almost 2 years ago)
- Topics: selenium-python, social-media, twitter, youtube
- Language: Python
- Homepage:
- Size: 790 KB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# social_media
A library for automating several social media actions, such as posting, login, notifications etc. for multiple social media and scraping data from these social medias. API free (no official social media APIs used), front-end selinium based solutions only.
### Social media platforms supported
### Installation
Will be uploaded to PyPI soon. Some versions will be uploaded to TestPyPI
### Cool updates:
**20th Dec: YOU CAN NOW VIEW YOUR INSTAGRAM FEED ON THE TERMINAL NOW**
NOTE: (only tested for linux till now)### Some random use cases
**USE CASE 1:**
Fetch profile of a twitter user1. Create twitter engine
```python
from social_media.twitter.base import TwitterEngine
t = TwitterEngine(patience=10) # patience is in seconds
```
or
```python
from social_media.base import Engine
t = Engine.select('twitter', patience=10)
```
2. Login (optional)
```python
t.login(read_from_env=True) # read from a .env file
```
or
```python
t.login(username="username", email="[email protected]", contact="123456789", password="password")
"""pass the username, contact, email and password manually.
(at least one of username, email or contact number is needed)
password is required"""
```
3. Get the profile of the person
```python
t.get_profile(username="@dannygonzalez") # I am truly greg (@ is optional, not really needed, also username should be exact)
```
4. Logout (optional)
```python
t.logout()
```
5. Close the browser window
```python
t.close(wait_for_input=False) # if wait_for_input is true then script will wait for the user to enter q to terminate
```**USE CASE 2:**
Download a yotube playlist ("Downloading VSauce's Mind Field series")```python
# example to download youtube playlists
from social_media.youtube.base import YouTubeEngine
y = YouTubeEngine() # init the engine object
y.login() # login to youtube account, needed if you want to add the playlist to your library
first_result = y.get_playlists('Mind Field') # search for playlist and get the first result
# first_result[0].add_playlist() optional step, if you want to add the playlist to your library
first_result[0].populate() # load video objects for all the contents of the playlist (can be skipped)
first_result[0].download() # download all videos in the playlist (internally populates the playlist if it is not populated)
y.logout() # logout from your youtube account
y.close()
```