GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-01-24T00:18:31Z,
for the dataset file:///shared/keolisamiens.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
N/A
Publisher URL:
N/A
Feed Email:
N/A
Feed Language:
N/A

Files included


  1. agency.txt
  2. calendar.txt
  3. calendar_dates.txt
  4. routes.txt
  5. stop_times.txt
  6. stops.txt
  7. trips.txt

Counts


  • Agencies: 0
  • Blocks: 0
  • Routes: 36
  • Shapes: 0
  • Stops: 779
  • Trips: 10579

Specification Compliance report

6915 notices reported (1 errors, 6914 warnings, 0 infos)

Notice Code Severity Total
invalid_row_length ERROR 1

invalid_row_length

Invalid csv row length.

A row in the input file has a different number of values than specified by the CSV header.

You can see more about this notice here.

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. rowLength (?) The length of the faulty record. headerCount (?) The number of column in the faulty file.
"agency.txt" 2 5 4
expired_calendar WARNING 63

expired_calendar

Dataset should not contain date ranges for services that have already expired.

This warning takes into account the calendar_dates.txt file as well as the calendar.txt file.

You can see more about this notice here.

Only the first 50 of 63 affected records are displayed below.

csvRowNumber (?) The row of the faulty record. serviceId (?) The service id of the faulty record.
2 "1_MERCREDI"
3 "1_L-MA-ME-J"
4 "1_SEMAINE"
5 "11_LUNDI"
6 "11_MARDI"
7 "11_MERCREDI"
8 "11_JEUDI"
9 "11_VENDREDI"
10 "11_SAMEDI"
11 "11_DIMANCHE"
12 "11_L-J-V"
13 "11_LUN-MAR"
14 "11_L-MA-ME-J"
15 "11_L-MA-J-V"
16 "11_SEMAINE"
17 "11_L-MA-V"
18 "11_MA-J-V"
19 "11_L-MA-J"
20 "11_JEU-VEN"
21 "12_MARDI"
22 "12_MERCREDI"
23 "12_JEUDI"
24 "12_VENDREDI"
25 "12_L-J-V"
26 "12_LUN-MAR"
27 "12_L-MA-ME-J"
28 "12_L-MA-J-V"
29 "12_SEMAINE"
30 "12_L-MA-V"
31 "12_MA-J-V"
32 "12_L-MA-J"
33 "12_JEU-VEN"
34 "13_DIMANCHE"
35 "15_LUNDI"
36 "15_MARDI"
37 "15_MERCREDI"
38 "15_JEUDI"
39 "15_VENDREDI"
40 "15_SAMEDI"
41 "15_DIMANCHE"
42 "15_L-J-V"
43 "15_LUN-MAR"
44 "15_L-MA-ME-J"
45 "15_L-MA-J-V"
46 "15_SEMAINE"
47 "15_L-MA-V"
48 "15_MA-J-V"
49 "15_L-MA-J"
50 "15_JEU-VEN"
51 "16_LUNDI"
fast_travel_between_consecutive_stops WARNING 38

fast_travel_between_consecutive_stops

A transit vehicle moves too fast between two consecutive stops.

The speed threshold depends on route type:

Route type Description Threshold, km/h
0 Light rail 100
1 Subway 150
2 Rail 500
3 Bus 150
4 Ferry 80
5 Cable tram 30
6 Aerial lift 50
7 Funicular 50
11 Trolleybus 150
12 Monorail 150
- Unknown 200

You can see more about this notice here.

tripCsvRowNumber (?) The row number of the problematic trip. tripId (?) `trip_id` of the problematic trip. routeId (?) `route_id` of the problematic trip. speedKph (?) Travel speed (km/h). distanceKm (?) Distance between stops (km). csvRowNumber1 (?) The row number of the first stop time. stopSequence1 (?) `stop_sequence` of the first stop. stopId1 (?) `stop_id` of the first stop. stopName1 (?) `stop_name` of the first stop. departureTime1 (?) `departure_time` of the first stop. csvRowNumber2 (?) The row number of the second stop time. stopSequence2 (?) `stop_sequence` of the second stop. stopId2 (?) `stop_id` of the second stop. stopName2 (?) `stop_name` of the second stop. arrivalTime2 (?) `arrival_time` of the second stop.
671 "15-12-4-5-172700" "12" 132.2171610285156 0.25708892422211366 193130 43 "176" "Col. JM Laurent" "18:20:00" 193131 44 "229" "Croix Rompue" "18:20:07"
598 "11-12-4-5-172700" "12" 132.2171610285156 0.25708892422211366 9645 43 "176" "Col. JM Laurent" "18:20:00" 9646 44 "229" "Croix Rompue" "18:20:07"
600 "11-12-8-5-190000" "12" 132.2171610285156 0.25708892422211366 10831 43 "176" "Col. JM Laurent" "19:48:00" 10832 44 "229" "Croix Rompue" "19:48:07"
673 "15-12-8-5-190000" "12" 132.2171610285156 0.25708892422211366 194316 43 "176" "Col. JM Laurent" "19:48:00" 194317 44 "229" "Croix Rompue" "19:48:07"
668 "15-12-7-5-160801" "12" 132.2171610285156 0.25708892422211366 194048 43 "176" "Col. JM Laurent" "17:02:00" 194049 44 "229" "Croix Rompue" "17:02:07"
595 "11-12-7-5-160801" "12" 132.2171610285156 0.25708892422211366 10563 43 "176" "Col. JM Laurent" "17:02:00" 10564 44 "229" "Croix Rompue" "17:02:07"
586 "11-12-1-5-102600" "12" 132.2171610285156 0.25708892422211366 8310 43 "176" "Col. JM Laurent" "11:14:00" 8311 44 "229" "Croix Rompue" "11:14:07"
659 "15-12-1-5-102600" "12" 132.2171610285156 0.25708892422211366 191795 43 "176" "Col. JM Laurent" "11:14:00" 191796 44 "229" "Croix Rompue" "11:14:07"
602 "11-12-6-5-193000" "12" 132.2171610285156 0.25708892422211366 10351 43 "176" "Col. JM Laurent" "20:18:00" 10352 44 "229" "Croix Rompue" "20:18:07"
675 "15-12-6-5-193000" "12" 132.2171610285156 0.25708892422211366 193836 43 "176" "Col. JM Laurent" "20:18:00" 193837 44 "229" "Croix Rompue" "20:18:07"
667 "15-12-1-5-154500" "12" 132.2171610285156 0.25708892422211366 192005 43 "176" "Col. JM Laurent" "16:35:00" 192006 44 "229" "Croix Rompue" "16:35:07"
594 "11-12-1-5-154500" "12" 132.2171610285156 0.25708892422211366 8520 43 "176" "Col. JM Laurent" "16:35:00" 8521 44 "229" "Croix Rompue" "16:35:07"
663 "15-12-1-5-130600" "12" 132.2171610285156 0.25708892422211366 191900 43 "176" "Col. JM Laurent" "13:55:00" 191901 44 "229" "Croix Rompue" "13:55:07"
590 "11-12-1-5-130600" "12" 132.2171610285156 0.25708892422211366 8415 43 "176" "Col. JM Laurent" "13:55:00" 8416 44 "229" "Croix Rompue" "13:55:07"
666 "15-12-4-5-150000" "12" 132.2171610285156 0.25708892422211366 193025 43 "176" "Col. JM Laurent" "15:50:00" 193026 44 "229" "Croix Rompue" "15:50:07"
593 "11-12-4-5-150000" "12" 132.2171610285156 0.25708892422211366 9540 43 "176" "Col. JM Laurent" "15:50:00" 9541 44 "229" "Croix Rompue" "15:50:07"
10434 "11-T40-4-2-130000" "T40" 101.67981941397662 0.4236659142249025 131727 2 "46" "Aquapôle" "13:00:39" 131728 3 "1093" "P. Cliniques" "13:00:54"
10442 "15-T40-4-2-130000" "T40" 101.67981941397662 0.4236659142249025 315212 2 "46" "Aquapôle" "13:00:39" 315213 3 "1093" "P. Cliniques" "13:00:54"
3765 "12-9-13-B-162000" "9" 148.75548966551173 0.28924678546071725 150231 1 "32" "Allonville" "16:20:00" 150232 2 "28" "Bout de Ville" "16:20:07"
3971 "16-9-13-B-162000" "9" 148.75548966551173 0.28924678546071725 333716 1 "32" "Allonville" "16:20:00" 333717 2 "28" "Bout de Ville" "16:20:07"
3695 "11-9-9-2-162000" "9" 148.75548966551173 0.28924678546071725 56474 1 "32" "Allonville" "16:20:00" 56475 2 "28" "Bout de Ville" "16:20:07"
3857 "15-9-12-A-162000" "9" 148.75548966551173 0.28924678546071725 235485 1 "32" "Allonville" "16:20:00" 235486 2 "28" "Bout de Ville" "16:20:07"
3651 "11-9-12-A-162000" "9" 148.75548966551173 0.28924678546071725 52000 1 "32" "Allonville" "16:20:00" 52001 2 "28" "Bout de Ville" "16:20:07"
3901 "15-9-9-2-162000" "9" 148.75548966551173 0.28924678546071725 239959 1 "32" "Allonville" "16:20:00" 239960 2 "28" "Bout de Ville" "16:20:07"
3765 "12-9-13-B-162000" "9" 171.1030766098849 0.23764316195817348 150232 2 "28" "Bout de Ville" "16:20:07" 150233 3 "472" "Moulin" "16:20:12"
3971 "16-9-13-B-162000" "9" 171.1030766098849 0.23764316195817348 333717 2 "28" "Bout de Ville" "16:20:07" 333718 3 "472" "Moulin" "16:20:12"
3695 "11-9-9-2-162000" "9" 171.1030766098849 0.23764316195817348 56475 2 "28" "Bout de Ville" "16:20:07" 56476 3 "472" "Moulin" "16:20:12"
3857 "15-9-12-A-162000" "9" 171.1030766098849 0.23764316195817348 235486 2 "28" "Bout de Ville" "16:20:07" 235487 3 "472" "Moulin" "16:20:12"
3651 "11-9-12-A-162000" "9" 171.1030766098849 0.23764316195817348 52001 2 "28" "Bout de Ville" "16:20:07" 52002 3 "472" "Moulin" "16:20:12"
3901 "15-9-9-2-162000" "9" 171.1030766098849 0.23764316195817348 239960 2 "28" "Bout de Ville" "16:20:07" 239961 3 "472" "Moulin" "16:20:12"
597 "11-12-8-5-163201" "12" 132.2171610285156 0.25708892422211366 10726 43 "176" "Col. JM Laurent" "17:26:00" 10727 44 "229" "Croix Rompue" "17:26:07"
670 "15-12-8-5-163201" "12" 132.2171610285156 0.25708892422211366 194211 43 "176" "Col. JM Laurent" "17:26:00" 194212 44 "229" "Croix Rompue" "17:26:07"
655 "15-12-1-5-080501" "12" 132.2171610285156 0.25708892422211366 191690 43 "176" "Col. JM Laurent" "08:55:00" 191691 44 "229" "Croix Rompue" "08:55:07"
582 "11-12-1-5-080501" "12" 132.2171610285156 0.25708892422211366 8205 43 "176" "Col. JM Laurent" "08:55:00" 8206 44 "229" "Croix Rompue" "08:55:07"
10438 "15-T40-9-A-153500" "T40" 101.67981941397662 0.4236659142249025 315234 2 "46" "Aquapôle" "15:35:39" 315235 3 "1093" "P. Cliniques" "15:35:54"
10430 "11-T40-9-A-153500" "T40" 101.67981941397662 0.4236659142249025 131749 2 "46" "Aquapôle" "15:35:39" 131750 3 "1093" "P. Cliniques" "15:35:54"
660 "15-12-5-5-112500" "12" 132.2171610285156 0.25708892422211366 193616 43 "176" "Col. JM Laurent" "12:15:00" 193617 44 "229" "Croix Rompue" "12:15:07"
587 "11-12-5-5-112500" "12" 132.2171610285156 0.25708892422211366 10131 43 "176" "Col. JM Laurent" "12:15:00" 10132 44 "229" "Croix Rompue" "12:15:07"
missing_recommended_file WARNING 1

missing_recommended_file

A recommended file is missing.

You can see more about this notice here.

filename (?) The name of the faulty file.
"feed_info.txt"
mixed_case_recommended_field WARNING 6807

mixed_case_recommended_field

This field has customer-facing text and should use Mixed Case (should contain upper and lower case letters).

This field contains customer-facing text and should use Mixed Case (upper and lower case letters) to ensure good readability when displayed to riders. Avoid the use of abbreviations throughout the feed (e.g. St. for Street) unless a location is called by its abbreviated name (e.g. “JFK Airport”). Abbreviations may be problematic for accessibility by screen reader software and voice user interfaces.

Good examples:
Field Text Dataset
"Schwerin, Hauptbahnhof" Verkehrsverbund Berlin-Brandenburg
"Red Hook/Atlantic Basin" NYC Ferry
"Campo Grande Norte" Carris
Bad examples:
Field Text
"GALLERIA MALL"
"3427 GG 17"
"21 Clark Rd Est"

You can see more about this notice here.

Only the first 50 of 6807 affected records are displayed below.

filename (?) Name of the faulty file. fieldName (?) Name of the faulty field. fieldValue (?) Faulty value. csvRowNumber (?) The row number of the faulty record.
"stops.txt" "stop_name" "3ème D.I." 4
"stops.txt" "stop_name" "3ème D.I." 5
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 2
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 3
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 4
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 5
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 6
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 7
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 8
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 9
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 10
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 11
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 12
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 13
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 14
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 15
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 16
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 17
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 18
"trips.txt" "trip_headsign" "BOVES M. BARBIER" 19
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 20
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 21
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 22
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 23
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 24
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 25
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 26
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 27
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 28
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 29
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 30
"trips.txt" "trip_headsign" "BOVES M. BARBIER" 31
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 32
"trips.txt" "trip_headsign" "BOVES M. BARBIER" 33
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 34
"trips.txt" "trip_headsign" "BOVES M. BARBIER" 35
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 36
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 37
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 38
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 39
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 40
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 41
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 42
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 43
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 44
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 45
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 46
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 47
"trips.txt" "trip_headsign" "CHU A. PICARDIE" 48
"trips.txt" "trip_headsign" "C. CIAL. GLISY" 49
stop_without_stop_time WARNING 4

stop_without_stop_time

A stop in stops.txt is not referenced by any stop_times.stop_id.

Such stops are not used by any trip and normally do not provide user value. This notice may indicate a typo in stop_times.txt.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. stopId (?) The id of the faulty stop. stopName (?) The name of the faulty stop.
255 "2083" "Dépôt Rivery"
256 "2082" "Dépôt Rivery"
345 "2087" "Gare du Nord A"
347 "2088" "Gare du Nord B"
trip_coverage_not_active_for_next7_days WARNING 1

trip_coverage_not_active_for_next7_days

Trips data should be valid for at least the next seven days.

This notice is triggered if the date range where a significant number of trips are running ends in less than 7 days.

You can see more about this notice here.

currentDate (?) Current date (YYYYMMDD format). serviceWindowStartDate (?) The start date of the majority service window. serviceWindowEndDate (?) The end date of the majority service window.
"20260124" "20231201" "20240705"