A module designed to automate the extraction of follower counts and post details from a public Facebook page.
Project description
MetaDataScraper
MetaDataScraper is a Python package designed to automate the extraction of information like follower counts, and post details & interactions from a public Facebook page, in the form of a list. It uses Selenium WebDriver for web automation and scraping.
The module provides two classes: LoginlessScraper
and LoggedInScraper
. The LoginlessScraper
class does not require any authentication or API keys to scrape the data. However, it has a drawback of being unable to access some Facebook pages.
The LoggedInScraper
class overcomes this drawback by utilising the credentials of a Facebook account (of user) to login and scrape the data.
Installation
You can install MetaDataScraper using pip:
pip install MetaDataScraper
Make sure you have Python 3.x and pip installed.
Usage
To use MetaDataScraper, follow these steps:
-
Import the
LoginlessScraper
or theLoggedInScraper
class:from MetaDataScraper import LoginlessScraper, LoggedInScraper
-
Initialize the scraper with the Facebook page ID:
page_id = "your_target_page_id" scraper = LoginlessScraper(page_id) email = "your_facebook_email" password = "your_facebook_password" scraper = LoggedInScraper(page_id, email, password)
-
Scrape the Facebook page to retrieve information:
result = scraper.scrape()
-
Access the scraped data from the result dictionary:
print(f"Followers: {result['followers']}") print(f"Post Texts: {result['post_texts']}") print(f"Post Likes: {result['post_likes']}") print(f"Post Shares: {result['post_shares']}") print(f"Is Video: {result['is_video']}") print(f"Video Links: {result['video_links']}")
Features
- Automated Extraction: Automatically fetches follower counts, post texts, likes, shares, and video links from Facebook pages.
- Comprehensive Data Retrieval: Retrieves detailed information about each post, including text content, interaction metrics (likes, shares), and multimedia (e.g., video links).
- Flexible Handling: Adapts to diverse post structures and various types of multimedia content present on Facebook pages, like post texts or reels.
- Enhanced Access with Logged-In Scraper: Overcomes limitations faced by anonymous scraping (loginless) by utilizing Facebook account credentials for broader page access.
- Headless Operation: Executes scraping tasks in headless mode, ensuring seamless and non-intrusive data collection without displaying a browser interface.
- Scalability: Supports scaling to handle large volumes of data extraction efficiently, suitable for monitoring multiple Facebook pages simultaneously.
- Dependency Management: Utilizes Selenium WebDriver for robust web automation and scraping capabilities, compatible with Python 3.x environments.
- Ease of Use: Simplifies the process with straightforward initialization and method calls, facilitating quick integration into existing workflows.
Dependencies
- selenium
- webdriver_manager
License
This project is licensed under the Apache Software License Version 2.0 - see the LICENSE file for details.
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 metadatascraper-1.0.1.tar.gz
.
File metadata
- Download URL: metadatascraper-1.0.1.tar.gz
- Upload date:
- Size: 12.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.19
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c35f1e6d527ef0d97a930a2b03eb72c374fa507c2324b80656073fbd082e3efa |
|
MD5 | e7aaa16ce4554980f9bbfe4b8096074b |
|
BLAKE2b-256 | 4fa9483b22a6a8f3fefc9b0c135cd0c778887bd901d4db0b404eae8c3c408322 |
File details
Details for the file MetaDataScraper-1.0.1-py3-none-any.whl
.
File metadata
- Download URL: MetaDataScraper-1.0.1-py3-none-any.whl
- Upload date:
- Size: 13.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.19
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | efbf520ac993454693470daa0db36926389916dbed8665c898987fbc31efe8d0 |
|
MD5 | c5653dd32bf18bd52ee7f97d8baa978e |
|
BLAKE2b-256 | 02ca6339c3f9323716513c31df3c5ba3878b2a12a23bbcd0e509128c77a6337a |