Skip to content

A simple and efficient python project for interacting with the NextBus API, which offers public transit information. The author's primary goal is to provide a valuable reference that can save you time and effort in your future projects.

License

Notifications You must be signed in to change notification settings

kaycee-okoye/nextbus_api_parser

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

NextBus API Python Parser

This Python package provides a simple and efficient way to interact with the NextBus API, which offers information on bus agencies, bus routes, bus stops, bus paths, and bus predictions in the United States. The repository includes four essential files:

  1. api_handler.py: This module acts as a controller for making API calls to the NextBus API. It also handles the parsing of API responses into appropriate model classes.

  2. data_classes.py: This module contains the model data classes used to represent and handle data parsed from the NextBus API. These classes help structure the data for easier manipulation and usage within your applications.

  3. xml_handler.py: The XML handler module includes classes that inherit from xml.sax.ContentHandler. These classes are responsible for parsing XML feeds from the NextBus API and transforming the data into the corresponding model classes.

  4. nextbus_predictor.py: This module implements a command-line interface (CLI) for requesting and displaying bus predictions for a selected bus stop along a selected route within a chosen bus agency. This module serves as a practical example of how to use the other components to interact with the NextBus API.

API documentation: https://retro.umoiq.com/xmlFeedDocs/NextBusXMLFeed.pdf

Getting Started

To get started with this project, follow these steps:

  1. Install the package to your local machine:

    pip install --upgrade pip
    pip install https://github.com/kaycee-okoye/nextbus_api_parser.git
  2. You can now use the provided command-line interface (CLI) to interact with the NextBus API and retrieve bus predictions.

Usage

The nextbus_predictor.py script provides a user-friendly CLI for interacting with the NextBus API. Here's how to use it:

python nextbus_predictor.py # you might need to provide the absolute path to this file

Follow the prompts to select a bus agency, route, and bus stop. The script will then fetch and display bus predictions for the chosen stop along the selected route.

Example

Welcome to the NextBus API Python Parser CLI!

Please select a bus agency:
1. Agency A
2. Agency B
3. Agency C
...

Enter your choice (1-10): 2

Please select a bus route:
1. Route X
2. Route Y
3. Route Z
...

Enter your choice (1-5): 1

Please select a bus stop:
1. Stop 1
2. Stop 2
3. Stop 3
...

Enter your choice (1-20): 3

Bus predictions for Route Y - Stop 3 (Agency B):

1. Prediction 1: Next bus in 5 minutes
2. Prediction 2: Next bus in 12 minutes
3. Prediction 3: Next bus in 20 minutes
...

Thank you for using the NextBus API Python Parser CLI!

Contributions Guidelines

Please read Contribution Guidelines for details on the author's code of conduct, and contribution guidelines.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Acknowledgments

Special thanks to the NextBus API team for providing access to real-time bus information, making public transportation more accessible to everyone.

Happy coding!

About

A simple and efficient python project for interacting with the NextBus API, which offers public transit information. The author's primary goal is to provide a valuable reference that can save you time and effort in your future projects.

Topics

Resources

License

Stars

Watchers

Forks

Languages