Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/phillipdupuis/mbta-api-playground
Learn about the MBTA V3 API by building queries and exploring the results
https://github.com/phillipdupuis/mbta-api-playground
data-exploration django django-rest-framework mbta-api pandas pandas-dataframe pandas-profiling python
Last synced: 6 days ago
JSON representation
Learn about the MBTA V3 API by building queries and exploring the results
- Host: GitHub
- URL: https://github.com/phillipdupuis/mbta-api-playground
- Owner: phillipdupuis
- License: mit
- Created: 2019-09-11T13:28:31.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-08T06:09:21.000Z (about 2 years ago)
- Last Synced: 2024-12-21T18:46:01.981Z (2 months ago)
- Topics: data-exploration, django, django-rest-framework, mbta-api, pandas, pandas-dataframe, pandas-profiling, python
- Language: Python
- Homepage: https://www.mbta-api-playground.com/
- Size: 1.69 MB
- Stars: 2
- Watchers: 2
- Forks: 1
- Open Issues: 16
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# MBTA API Playground
[https://www.mbta-api-playground.com/](https://www.mbta-api-playground.com/)
Learn how to work with the MBTA V3 API by constructing queries and interacting with the results.## Creating queries
Users can build queries in which they specify:
* The primary object (ex: Alert, Route, Facility, Vehicle, etc.)
* The related objects that should also be included in the results
* The attributes that should be returned for each object
* Filters for limiting what object instances are returned## Viewing results
Upon executing a query, the user is brought to a results page where they can view:
* A brief summary of the response (status code, size, and query parameters)
* A table of the response data
* It can be downloaded as a CSV file for further analysis
* A profile report generated by [pandas-profiling](https://github.com/pandas-profiling/pandas-profiling)
* Users can customize what correlations are calculated
* The raw response data as pretty-printed JSON
* Interactive geolocation plots for any objects which have 'latitude' and 'longitude' attributes.
* These plots are generated using [Bokeh](https://bokeh.pydata.org/en/latest/docs/user_guide/geo.html)## Built With
* Django
* Django REST framework
* Vanilla ES6 JavaScript (the only exception is jQuery was used for showing/hiding modals)## Example: finding facilities which have bike storage or electric car chargers
Creating the query
data:image/s3,"s3://crabby-images/4ec01/4ec01e8957d18a0eed2603c1c8b136bd4b1d6e2b" alt="filtered facility query"Results: Summary
data:image/s3,"s3://crabby-images/6d4c1/6d4c1544c82a5b9c15f6375a062e1d58e7498e4c" alt="results summary"Results: Table
data:image/s3,"s3://crabby-images/2eb23/2eb2391d40ca9d734bef4840a534ccb1da972ba4" alt="results table"Results: Report
data:image/s3,"s3://crabby-images/12983/12983a8b098395fd9dda4e95246b6c6ab91fc65b" alt="results report"Results: JSON
data:image/s3,"s3://crabby-images/b2764/b2764e53a5a89ea6e0a40016f0af22949dcaf31b" alt="results json"Results: Locations
data:image/s3,"s3://crabby-images/fa8d8/fa8d816bc06117e16f99d954364facf50e74e384" alt="results locations"