No description
Find a file
2026-04-01 14:33:10 +01:00
scraper Generate Eurostar timetable URLs from station IDs 2026-04-01 12:17:50 +01:00
templates Add same-day destination switcher to results 2026-04-01 12:50:43 +01:00
tests Add app route tests and fix stale assertions 2026-04-01 14:33:10 +01:00
.gitignore Initial commit. 2026-03-30 19:34:46 +01:00
app.py Add same-day destination switcher to results 2026-04-01 12:50:43 +01:00
cache.py Initial commit. 2026-03-30 19:34:46 +01:00
pyproject.toml Initial commit. 2026-03-30 19:34:46 +01:00
README.md Include link to git repo. 2026-03-31 15:13:11 +01:00
requirements.txt Initial commit. 2026-03-30 19:34:46 +01:00
trip_planner.py Various improvements 2026-03-31 12:59:44 +01:00

Bristol Eurostar

Source: https://git.4angle.com/edward/bristol-eurostar

Plan a trip from Bristol Temple Meads to Europe on Eurostar.

Combines GWR trains (Bristol → Paddington) with Eurostar services (St Pancras → destination) and shows all valid same-day connections, filtering by journey time and minimum/maximum transfer window at Paddington/St Pancras.

Destinations

  • Paris Gare du Nord
  • Brussels Midi
  • Lille Europe
  • Amsterdam Centraal

How it works

Train times are fetched from two sources simultaneously:

  • GWR — scraped from Realtime Trains using httpx
  • Eurostar — scraped from the Eurostar timetable pages via the embedded __NEXT_DATA__ JSON (no browser required)

Results are cached to disk by date and destination.

Connection constraints

Minimum Paddington → St Pancras 75 min
Maximum Paddington → St Pancras 2h 20m
Maximum Bristol → Paddington 1h 50m

Setup

pip install -e ".[dev]"

Running

flask --app app run

Then open http://localhost:5000.

Tests

pytest

License

MIT