PHPackages                             megamindame/school\_scraper - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Parsing &amp; Serialization](/categories/parsing)
4. /
5. megamindame/school\_scraper

ActiveProject[Parsing &amp; Serialization](/categories/parsing)

megamindame/school\_scraper
===========================

This package scrapes all Tanzania's schools from Necta's website.

v0.01(2y ago)943[2 issues](https://github.com/MegamindAme/school-scrapper/issues)MITPHPPHP &gt;= 7.0

Since Jul 7Pushed 2y ago1 watchersCompare

[ Source](https://github.com/MegamindAme/school-scrapper)[ Packagist](https://packagist.org/packages/megamindame/school_scraper)[ RSS](/packages/megamindame-school-scraper/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (1)Dependencies (1)Versions (3)Used By (0)

school-scrapper
===============

[](#school-scrapper)

A package to scrape Tanzania schools

Usage
-----

[](#usage)

Add the package from the composer by running `composer require megamindame/school_scraper`

If you want to get school data by using this package, not use it in your code, you can uncomment the code section you want in the App.php file,

Using the Package
-----------------

[](#using-the-package)

3 types of data can be accessed from 3 education levels. Education levels 1) Primary 2) Secondary 3)Advanced Secondary

### Data that can be accessed

[](#data-that-can-be-accessed)

1. schools - An array of formatted school data
2. nodes - XPath nodelist of all the html link tags. You can iterate through the list to scrape the results page of a school. Check the Xpath documentation to see how you can use the Xpath node.
3. data - An array of un-formatted school data

### Accessing the data

[](#accessing-the-data)

You can initialize any of the fetchers and pass the year you want to fetch. Images are embedded to show the returned data format.

#### 1) Primary

[](#1-primary)

```
$fetcher = new PrimaryFetcher(2022);

//Get Primary schools
return $fetcher->getSchools();

```

[![image](https://private-user-images.githubusercontent.com/71287850/251599843-f90a7cee-9cb8-45f6-9430-e7a63f87438c.png?jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3NzU1NDU5NjMsIm5iZiI6MTc3NTU0NTY2MywicGF0aCI6Ii83MTI4Nzg1MC8yNTE1OTk4NDMtZjkwYTdjZWUtOWNiOC00NWY2LTk0MzAtZTdhNjNmODc0MzhjLnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNjA0MDclMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjYwNDA3VDA3MDc0M1omWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPTU1ZjJlMDhlNTFjMTY4ODgxMzhmZDUwMzQ4ZTA5MTkzNDI2ODU3OWZjMDVkYTkzODY3MjI0ZjRiMjQwMjU2NDYmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0In0.nnezKarneWMMEjcdKDeckXiPMxYcElZ29abZbzotphc)](https://private-user-images.githubusercontent.com/71287850/251599843-f90a7cee-9cb8-45f6-9430-e7a63f87438c.png?jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3NzU1NDU5NjMsIm5iZiI6MTc3NTU0NTY2MywicGF0aCI6Ii83MTI4Nzg1MC8yNTE1OTk4NDMtZjkwYTdjZWUtOWNiOC00NWY2LTk0MzAtZTdhNjNmODc0MzhjLnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNjA0MDclMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjYwNDA3VDA3MDc0M1omWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPTU1ZjJlMDhlNTFjMTY4ODgxMzhmZDUwMzQ4ZTA5MTkzNDI2ODU3OWZjMDVkYTkzODY3MjI0ZjRiMjQwMjU2NDYmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0In0.nnezKarneWMMEjcdKDeckXiPMxYcElZ29abZbzotphc)

```
//Get Data
return $fetcher->getPrimaryData();

```

[![image](https://private-user-images.githubusercontent.com/71287850/251599183-b805f4ec-c710-4fe0-9f7a-63760ad2e6a1.png?jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3NzU1NDU5NjMsIm5iZiI6MTc3NTU0NTY2MywicGF0aCI6Ii83MTI4Nzg1MC8yNTE1OTkxODMtYjgwNWY0ZWMtYzcxMC00ZmUwLTlmN2EtNjM3NjBhZDJlNmExLnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNjA0MDclMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjYwNDA3VDA3MDc0M1omWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPWJjZDkzMDJmNWU1N2JjYWM4ZjYwMjg2YjZhYjE4N2RiMGNmOTg5NTc1ZDQ5YThiOWFiODA1Yjc4MGU3OWRkODkmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0In0.MrU8CWFj3DnKlA0URv4VbBBjgX0nJUw7fEtG6XbNM7Y)](https://private-user-images.githubusercontent.com/71287850/251599183-b805f4ec-c710-4fe0-9f7a-63760ad2e6a1.png?jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3NzU1NDU5NjMsIm5iZiI6MTc3NTU0NTY2MywicGF0aCI6Ii83MTI4Nzg1MC8yNTE1OTkxODMtYjgwNWY0ZWMtYzcxMC00ZmUwLTlmN2EtNjM3NjBhZDJlNmExLnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNjA0MDclMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjYwNDA3VDA3MDc0M1omWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPWJjZDkzMDJmNWU1N2JjYWM4ZjYwMjg2YjZhYjE4N2RiMGNmOTg5NTc1ZDQ5YThiOWFiODA1Yjc4MGU3OWRkODkmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0In0.MrU8CWFj3DnKlA0URv4VbBBjgX0nJUw7fEtG6XbNM7Y)

```
//Get Nodes
return $fetcher->getNodes();

```

#### 2) Secondary and Advanced Secondary

[](#2-secondary-and-advanced-secondary)

```
$fetcher = new SecondaryFetcher(2022);
//or
$fetcher = new AdvancedSecondaryFetcher(2022);

//Get Primary schools
return $fetcher->getSchools();

```

[![image](https://private-user-images.githubusercontent.com/71287850/251598077-d0ed791c-4dc7-46a6-89ce-1498cc664c05.png?jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3NzU1NDU5NjMsIm5iZiI6MTc3NTU0NTY2MywicGF0aCI6Ii83MTI4Nzg1MC8yNTE1OTgwNzctZDBlZDc5MWMtNGRjNy00NmE2LTg5Y2UtMTQ5OGNjNjY0YzA1LnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNjA0MDclMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjYwNDA3VDA3MDc0M1omWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPTdkOGNlNjM1YjAxMWM0NzQ3MzdlNzkyNDA2NTRkMmUwZmUzOThlODVkZDllNGRhOTM4OTgxOTYwMTJmNTVmZDEmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0In0.sQvdf7pweIRLoaP2pBqC3zqVu4rh0XkObR-8UyV3-zk)](https://private-user-images.githubusercontent.com/71287850/251598077-d0ed791c-4dc7-46a6-89ce-1498cc664c05.png?jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3NzU1NDU5NjMsIm5iZiI6MTc3NTU0NTY2MywicGF0aCI6Ii83MTI4Nzg1MC8yNTE1OTgwNzctZDBlZDc5MWMtNGRjNy00NmE2LTg5Y2UtMTQ5OGNjNjY0YzA1LnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNjA0MDclMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjYwNDA3VDA3MDc0M1omWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPTdkOGNlNjM1YjAxMWM0NzQ3MzdlNzkyNDA2NTRkMmUwZmUzOThlODVkZDllNGRhOTM4OTgxOTYwMTJmNTVmZDEmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0In0.sQvdf7pweIRLoaP2pBqC3zqVu4rh0XkObR-8UyV3-zk)

```
//Get Data
return $fetcher->getData();

```

[![image](https://private-user-images.githubusercontent.com/71287850/251598257-01f94981-bafa-4ff4-b247-d5d84fda416d.png?jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3NzU1NDU5NjMsIm5iZiI6MTc3NTU0NTY2MywicGF0aCI6Ii83MTI4Nzg1MC8yNTE1OTgyNTctMDFmOTQ5ODEtYmFmYS00ZmY0LWIyNDctZDVkODRmZGE0MTZkLnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNjA0MDclMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjYwNDA3VDA3MDc0M1omWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPTk3ZGQxNmFmYWE1NzYyNzE2YzliNjAyZjUxYmMwMTE3MDg1ODA5MjZjMTNiYTBiYjAyMDZkODEyNDQ0N2RmNWEmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0In0.4YwrMKZi73gGBF7IEwKy-UIEZ6FT9rG1hWTedq0SnPI)](https://private-user-images.githubusercontent.com/71287850/251598257-01f94981-bafa-4ff4-b247-d5d84fda416d.png?jwt=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3NzU1NDU5NjMsIm5iZiI6MTc3NTU0NTY2MywicGF0aCI6Ii83MTI4Nzg1MC8yNTE1OTgyNTctMDFmOTQ5ODEtYmFmYS00ZmY0LWIyNDctZDVkODRmZGE0MTZkLnBuZz9YLUFtei1BbGdvcml0aG09QVdTNC1ITUFDLVNIQTI1NiZYLUFtei1DcmVkZW50aWFsPUFLSUFWQ09EWUxTQTUzUFFLNFpBJTJGMjAyNjA0MDclMkZ1cy1lYXN0LTElMkZzMyUyRmF3czRfcmVxdWVzdCZYLUFtei1EYXRlPTIwMjYwNDA3VDA3MDc0M1omWC1BbXotRXhwaXJlcz0zMDAmWC1BbXotU2lnbmF0dXJlPTk3ZGQxNmFmYWE1NzYyNzE2YzliNjAyZjUxYmMwMTE3MDg1ODA5MjZjMTNiYTBiYjAyMDZkODEyNDQ0N2RmNWEmWC1BbXotU2lnbmVkSGVhZGVycz1ob3N0In0.4YwrMKZi73gGBF7IEwKy-UIEZ6FT9rG1hWTedq0SnPI)

```
//Get Nodes
return $fetcher->getNodes();

```

People who want to fetch results from the nodes can use the Fetcher-&gt;getRootUrl() method to get the Root Url. You can take a look at the code to see how the nodes can be used to fetch their corresponding web pages, in this case, school results pages

As stated above, if you want to use the package as a standalone, then you can just download the code, run ` composer install ` then check the 'App.php' file for some directions on how to fetch data. Try to uncomment the sections inside the file, then run `php index.php`. You can try to run `php index.php > filename` to save the echoed data into a file.

###  Health Score

18

—

LowBetter than 8% of packages

Maintenance16

Infrequent updates — may be unmaintained

Popularity11

Limited adoption so far

Community9

Small or concentrated contributor base

Maturity30

Early-stage or recently created project

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Unknown

Total

1

Last Release

1040d ago

### Community

Maintainers

![](https://www.gravatar.com/avatar/5ff520577017a352d61056a41c21980fd3580ce1349f8947c93f84988a36900e?d=identicon)[MegamindAme](/maintainers/MegamindAme)

---

Top Contributors

[![MegamindAme](https://avatars.githubusercontent.com/u/71287850?v=4)](https://github.com/MegamindAme "MegamindAme (6 commits)")

### Embed Badge

![Health badge](/badges/megamindame-school-scraper/health.svg)

```
[![Health](https://phpackages.com/badges/megamindame-school-scraper/health.svg)](https://phpackages.com/packages/megamindame-school-scraper)
```

###  Alternatives

[sauladam/shipment-tracker

Parses tracking information for several carriers, like UPS, USPS, DHL and GLS by simply scraping the data. No need for any kind of API access.

9738.8k](/packages/sauladam-shipment-tracker)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
