dati-aspo — Source Data Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-03-27T16:23:54Z,
for the dataset file:///shared/dati-aspo_6d4963eb.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
ASPO S.p.a
Publisher URL:
http://www.aspo.it/
Feed Email:
info@aspo.it
Feed Language:
Italian
Feed Start Date:
2026-01-05
Feed End Date:
2026-06-14

Files included


  1. agency.txt
  2. calendar.txt
  3. calendar_dates.txt
  4. feed_info.txt
  5. routes.txt
  6. shapes.txt
  7. stop_times.txt
  8. stops.txt
  9. transfers.txt
  10. trips.txt

Counts


  • Agencies: 1
  • Blocks: 0
  • Routes: 15
  • Shapes: 70
  • Stops: 424
  • Trips: 432

Specification Compliance report

17177 notices reported (4 errors, 17173 warnings, 0 infos)

Notice Code Severity Total
trip_distance_exceeds_shape_distance ERROR 4

trip_distance_exceeds_shape_distance

The distance between the last shape point and last stop point is greater than or equal to the 11.1m threshold.

You can see more about this notice here.

tripId (?) The faulty record's trip id. shapeId (?) The faulty record's shape id. maxTripDistanceTraveled (?) The faulty record's trip max distance traveled. maxShapeDistanceTraveled (?) The faulty record's shape max distance traveled. geoDistanceToShape (?) The distance in meters between the shape and the stop.
"215020" "SHAPEID_172" 34.45 33.961 384.99023656613707
"216650" "SHAPEID_429" 15.731 15.724 17.21766481453305
"216651" "SHAPEID_429" 15.731 15.724 17.21766481453305
"216658" "SHAPEID_429" 15.731 15.724 17.21766481453305
expired_calendar WARNING 1

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.

csvRowNumber (?) The row of the faulty record. serviceId (?) The service id of the faulty record.
3 "AN-FER1"
fast_travel_between_consecutive_stops WARNING 281

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.

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

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.
366 "216361" "10" 152.3555595358777 1.2696296627989807 14433 19 "1001" "Colcò" "15:51:53" 14434 20 "832" "Cimitero Nuovo" "15:52:23"
300 "216292" "08" 636.5957802598986 0.17683216118330516 12566 2 "865" "Fr. ex trib." "15:52:00" 12567 3 "864" "Fronte ex tribunale" "15:52:01"
300 "216292" "08" 869.5715768089877 0.24154766022471882 12570 6 "1198" "Via Ferrara civ. 55" "15:55:01" 12571 7 "859" "Via Belluno 70" "15:55:02"
300 "216292" "08" 495.4728624296631 0.13763135067490642 12572 8 "858" "Via Messico" "15:56:02" 12573 9 "829" "Via Pistoia, lato civ. pari" "15:56:03"
300 "216292" "08" 254.09038078294836 0.07058066132859676 12573 9 "829" "Via Pistoia, lato civ. pari" "15:56:03" 12574 10 "836" "Via Gran Bretagna civ.19" "15:56:04"
300 "216292" "08" 594.7177186862656 0.16519936630174045 12575 11 "853" "Via Messico V.Austria" "15:57:04" 12576 12 "852" "Via Ungheria Nespoli" "15:57:05"
300 "216292" "08" 352.2988558139362 0.09786079328164894 12579 15 "866" "Lituania fr. pescheria" "15:58:58" 12580 16 "870" "Roma Cervo" "15:58:59"
300 "216292" "08" 253.88028321802958 0.0705223008938971 12584 20 "155" "Via San Simplicio 6" "16:02:59" 12585 21 "154" "Necropoli S.Simplicio" "16:03:00"
300 "216292" "08" 477.2140945620742 0.13255947071168728 12585 21 "154" "Necropoli S.Simplicio" "16:03:00" 12586 22 "153" "Via D'Annunzio stazione FS" "16:03:01"
300 "216292" "08" 736.0945481820161 0.2044707078283378 12586 22 "153" "Via D'Annunzio stazione FS" "16:03:01" 12587 23 "152" "Via D'Annunzio fronte Carabinieri" "16:03:02"
369 "216364" "02" 185.4988662984176 1.5458238858201467 14484 4 "953" "SS125 fr.Padrongianus" "23:01:30" 14485 5 "951" "SS125 lato Comm" "23:02:00"
336 "216329" "12" 1372.0352130811511 0.381120892522542 13782 3 "2008" "Trainu Moltu dir. Olbia" "15:48:00" 13783 4 "2018" "Sos Coddos dir. Olbia" "15:48:01"
336 "216329" "12" 6225.280107710714 1.7292444743640873 13784 5 "2012" "Via Rio sos Campitos dir. Olbia" "15:49:01" 13785 6 "2020" "Via Olivà dir. Olbia" "15:49:02"
336 "216329" "12" 954.7071705649103 0.26519643626803063 13788 9 "1058" "Via Nazionale fr.70" "15:56:02" 13789 10 "1057" "Via Nazionale fr.1" "15:56:03"
336 "216329" "12" 3879.408685562433 1.0776135237673425 13795 16 "832" "Cimitero Nuovo" "16:08:03" 13796 17 "2083" "Via Loiri, Istituto I.P.A.A." "16:08:04"
336 "216329" "12" 1283.0633080365494 0.35640647445459706 13797 18 "1051" "Colcò agraria" "16:11:04" 13798 19 "841" "V.Venafiorita fr. Trib." "16:11:05"
336 "216329" "12" 624.94046524446 0.17359457367901668 13799 20 "815" "Via Venafiorita" "16:12:05" 13800 21 "873" "Via Roma fr. Cimitero" "16:12:06"
336 "216329" "12" 829.9373170726602 0.23053814363129452 13804 25 "157" "Mameli fr.Casermette" "16:15:29" 13805 26 "156" "Via Mameli 1" "16:15:30"
336 "216329" "12" 473.1405160194339 0.13142792111650942 13805 26 "156" "Via Mameli 1" "16:15:30" 13806 27 "155" "Via San Simplicio 6" "16:15:31"
336 "216329" "12" 477.2140945620742 0.13255947071168728 13807 28 "154" "Necropoli S.Simplicio" "16:16:31" 13808 29 "153" "Via D'Annunzio stazione FS" "16:16:32"
336 "216329" "12" 736.0945481820161 0.2044707078283378 13808 29 "153" "Via D'Annunzio stazione FS" "16:16:32" 13809 30 "152" "Via D'Annunzio fronte Carabinieri" "16:16:33"
336 "216329" "12" 1070.9708408187294 0.29749190022742483 13810 31 "151" "Centro Martini" "16:17:33" 13811 32 "201" "Via Dei Lidi fr.5" "16:17:34"
336 "216329" "12" 1074.4018692421962 0.29844496367838785 13812 33 "202" "Via Dei Lidi fr.69" "16:18:34" 13813 34 "231" "V. Indonesia fr Mc" "16:18:35"
336 "216329" "12" 780.9463142207097 0.2169295317279749 13813 34 "231" "V. Indonesia fr Mc" "16:18:35" 13814 35 "232" "Fronte ASPO" "16:18:36"
70 "213906" "02" 203.19613837907488 0.5644337177196525 2835 1 "2088" "Nicosia" "20:50:00" 2836 2 "2096" "2096 - Via Mosca" "20:50:10"
365 "216360" "10" 152.3555595358777 1.2696296627989807 14411 19 "1001" "Colcò" "15:11:53" 14412 20 "832" "Cimitero Nuovo" "15:12:23"
355 "216350" "10" 152.3555595358777 1.2696296627989807 14191 19 "1001" "Colcò" "08:21:53" 14192 20 "832" "Cimitero Nuovo" "08:22:23"
368 "216363" "10" 152.3555595358777 1.2696296627989807 14477 19 "1001" "Colcò" "17:11:53" 14478 20 "832" "Cimitero Nuovo" "17:12:23"
179 "215251" "02" 932.1375284758118 0.25892709124328106 8100 1 "491" "Porto Rotondo" "07:00:00" 8101 2 "416" "P.Rotondo P.zza Krizia" "07:00:01"
179 "215251" "02" 1742.4674168478873 0.4840187269021909 8112 13 "405" "V.le Rudalza" "07:11:01" 8113 14 "404" "SP73 Vivaio" "07:11:02"
179 "215251" "02" 1039.9496533293193 0.28887490370258867 8113 14 "404" "SP73 Vivaio" "07:11:02" 8114 15 "2092" "OlbiaVia Picciaredda" "07:11:03"
179 "215251" "02" 685.3354161193002 0.19037094892202786 8116 17 "402" "SP73" "07:13:03" 8117 18 "2089" "sp 125 lato ristorante" "07:13:04"
299 "216291" "08" 636.5957802598986 0.17683216118330516 12535 2 "865" "Fr. ex trib." "15:12:00" 12536 3 "864" "Fronte ex tribunale" "15:12:01"
299 "216291" "08" 869.5715768089877 0.24154766022471882 12539 6 "1198" "Via Ferrara civ. 55" "15:15:01" 12540 7 "859" "Via Belluno 70" "15:15:02"
299 "216291" "08" 495.4728624296631 0.13763135067490642 12541 8 "858" "Via Messico" "15:16:02" 12542 9 "829" "Via Pistoia, lato civ. pari" "15:16:03"
299 "216291" "08" 254.09038078294836 0.07058066132859676 12542 9 "829" "Via Pistoia, lato civ. pari" "15:16:03" 12543 10 "836" "Via Gran Bretagna civ.19" "15:16:04"
299 "216291" "08" 594.7177186862656 0.16519936630174045 12544 11 "853" "Via Messico V.Austria" "15:17:04" 12545 12 "852" "Via Ungheria Nespoli" "15:17:05"
299 "216291" "08" 352.2988558139362 0.09786079328164894 12548 15 "866" "Lituania fr. pescheria" "15:18:58" 12549 16 "870" "Roma Cervo" "15:18:59"
299 "216291" "08" 253.88028321802958 0.0705223008938971 12553 20 "155" "Via San Simplicio 6" "15:22:59" 12554 21 "154" "Necropoli S.Simplicio" "15:23:00"
299 "216291" "08" 477.2140945620742 0.13255947071168728 12554 21 "154" "Necropoli S.Simplicio" "15:23:00" 12555 22 "153" "Via D'Annunzio stazione FS" "15:23:01"
299 "216291" "08" 736.0945481820161 0.2044707078283378 12555 22 "153" "Via D'Annunzio stazione FS" "15:23:01" 12556 23 "152" "Via D'Annunzio fronte Carabinieri" "15:23:02"
302 "216294" "08" 636.5957802598986 0.17683216118330516 12628 2 "865" "Fr. ex trib." "17:12:00" 12629 3 "864" "Fronte ex tribunale" "17:12:01"
302 "216294" "08" 869.5715768089877 0.24154766022471882 12632 6 "1198" "Via Ferrara civ. 55" "17:15:01" 12633 7 "859" "Via Belluno 70" "17:15:02"
302 "216294" "08" 495.4728624296631 0.13763135067490642 12634 8 "858" "Via Messico" "17:16:02" 12635 9 "829" "Via Pistoia, lato civ. pari" "17:16:03"
302 "216294" "08" 254.09038078294836 0.07058066132859676 12635 9 "829" "Via Pistoia, lato civ. pari" "17:16:03" 12636 10 "836" "Via Gran Bretagna civ.19" "17:16:04"
302 "216294" "08" 594.7177186862656 0.16519936630174045 12637 11 "853" "Via Messico V.Austria" "17:17:04" 12638 12 "852" "Via Ungheria Nespoli" "17:17:05"
302 "216294" "08" 352.2988558139362 0.09786079328164894 12641 15 "866" "Lituania fr. pescheria" "17:18:58" 12642 16 "870" "Roma Cervo" "17:18:59"
302 "216294" "08" 253.88028321802958 0.0705223008938971 12646 20 "155" "Via San Simplicio 6" "17:22:59" 12647 21 "154" "Necropoli S.Simplicio" "17:23:00"
302 "216294" "08" 477.2140945620742 0.13255947071168728 12647 21 "154" "Necropoli S.Simplicio" "17:23:00" 12648 22 "153" "Via D'Annunzio stazione FS" "17:23:01"
302 "216294" "08" 736.0945481820161 0.2044707078283378 12648 22 "153" "Via D'Annunzio stazione FS" "17:23:01" 12649 23 "152" "Via D'Annunzio fronte Carabinieri" "17:23:02"
leading_or_trailing_whitespaces WARNING 1

leading_or_trailing_whitespaces

The value in CSV file has leading or trailing whitespaces.

This notice is emitted for values protected with double quotes since whitespaces for non-protected values are trimmed automatically by CSV parser.

The validator strips whitespaces from protected values. We do not see any use case when such a whitespace may be needed. On the other hand, some real-world feeds use trailing whitespaces for some values and omit them for the others. This is causing the largest problem when a primary key and a foreign key differ just by a whitespace: it is clear that they are intended to be the same, that is why we always strip whitespaces.

You can see more about this notice here.

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. fieldName (?) Faulty record's field name. fieldValue (?) Faulty value.
"stops.txt" 78 "stop_name" "Via Viterbo, 9 "
missing_timepoint_value WARNING 16706

missing_timepoint_value

stop_times.timepoint value is missing for a record.

When at least one of stop_times.arrival_time or stop_times.departure_time are provided, stop_times.timepoint should be defined

You can see more about this notice here.

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

csvRowNumber (?) The row number of the faulty record. tripId (?) The faulty record's `stop_times.trip_id`. stopSequence (?) The faulty record's `stop_times.stop_sequence`.
2 "212619" 1
3 "212619" 2
4 "212619" 3
5 "212619" 4
6 "212619" 5
7 "212619" 6
8 "212619" 7
9 "212619" 8
10 "212619" 9
11 "212619" 10
12 "212619" 11
13 "212619" 12
14 "212619" 13
15 "212619" 14
16 "212619" 15
17 "212619" 16
18 "212619" 17
19 "212619" 18
20 "212619" 19
21 "212620" 1
22 "212620" 2
23 "212620" 3
24 "212620" 4
25 "212620" 5
26 "212620" 6
27 "212620" 7
28 "212620" 8
29 "212620" 9
30 "212620" 10
31 "212620" 11
32 "212620" 12
33 "212620" 13
34 "212620" 14
35 "212620" 15
36 "212620" 16
37 "212620" 17
38 "212620" 18
39 "212620" 19
40 "212622" 1
41 "212622" 2
42 "212622" 3
43 "212622" 4
44 "212622" 5
45 "212622" 6
46 "212622" 7
47 "212622" 8
48 "212622" 9
49 "212622" 10
50 "212622" 11
51 "212622" 12
mixed_case_recommended_field WARNING 175

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 175 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.
"routes.txt" "route_long_name" "RINFORZO SCOLASTICO LINEA 4" 16
"stops.txt" "stop_name" "BASA-PARK" 10
"stops.txt" "stop_name" "SP n°79 fronte civico 10" 48
"stops.txt" "stop_name" "sp 125 lato ristorante" 86
"stops.txt" "stop_name" "SS 125, civ. 20" 91
"stops.txt" "stop_name" "SS125 ex SAFA" 183
"stops.txt" "stop_name" "SS127 km 6.200" 345
"trips.txt" "trip_short_name" "01DEP-R_1" 2
"trips.txt" "trip_short_name" "01DEP-R_2" 3
"trips.txt" "trip_short_name" "01DEP-A_1" 4
"trips.txt" "trip_short_name" "01DEP-A_2" 5
"trips.txt" "trip_short_name" "01DEP-A_3" 6
"trips.txt" "trip_short_name" "01SCO" 7
"trips.txt" "trip_short_name" "01DEP-A_1" 8
"trips.txt" "trip_short_name" "01DEP-R_3" 9
"trips.txt" "trip_short_name" "02dep2" 10
"trips.txt" "trip_short_name" "02dep3" 11
"trips.txt" "trip_short_name" "0502-R_FES" 21
"trips.txt" "trip_short_name" "0503-R_FES" 22
"trips.txt" "trip_short_name" "0505-R_FES" 23
"trips.txt" "trip_short_name" "0611DEP-R" 30
"trips.txt" "trip_short_name" "0724DEP-R" 31
"trips.txt" "trip_short_name" "09DEP-A1" 32
"trips.txt" "trip_short_name" "09DEP-A2" 33
"trips.txt" "trip_short_name" "09DEP-R2" 34
"trips.txt" "trip_short_name" "02RD-3" 41
"trips.txt" "trip_short_name" "0502-R_FER" 42
"trips.txt" "trip_short_name" "0503-R_FER" 43
"trips.txt" "trip_short_name" "0505-R_FER" 44
"trips.txt" "trip_short_name" "02RD-1" 69
"trips.txt" "trip_short_name" "02RD-2" 70
"trips.txt" "trip_short_name" "0102-AS" 74
"trips.txt" "trip_short_name" "0103-AS" 75
"trips.txt" "trip_short_name" "0104-AS" 76
"trips.txt" "trip_short_name" "0105-AS" 77
"trips.txt" "trip_short_name" "0106-AS" 78
"trips.txt" "trip_short_name" "0107-AS" 79
"trips.txt" "trip_short_name" "0108-AS" 80
"trips.txt" "trip_short_name" "0109-AS" 81
"trips.txt" "trip_short_name" "0110-AS" 82
"trips.txt" "trip_short_name" "0111-AS" 83
"trips.txt" "trip_short_name" "0112-AS" 84
"trips.txt" "trip_short_name" "0113-AS" 85
"trips.txt" "trip_short_name" "0114-AS" 86
"trips.txt" "trip_short_name" "0116-AS" 87
"trips.txt" "trip_short_name" "0118-AS" 88
"trips.txt" "trip_short_name" "0119-AS" 89
"trips.txt" "trip_short_name" "0120-AS" 90
"trips.txt" "trip_short_name" "0121-AS" 91
"trips.txt" "trip_short_name" "0122-AS" 92
route_color_contrast WARNING 3

route_color_contrast

Insufficient route color contrast.

A route's color and route_text_color should be contrasting.

You can see more about this notice here.

routeId (?) The id of the faulty record. csvRowNumber (?) The row number of the faulty record. routeColor (?) The faulty record's HTML route color. routeTextColor (?) The faulty record's HTML route text color.
"04" 5 "#80FFFF" "#FFFFFF"
"06" 7 "#80FF80" "#FFFFFF"
"09" 10 "#EBA88B" "#FFFFFF"
stop_too_far_from_shape_using_user_distance WARNING 2

stop_too_far_from_shape_using_user_distance

Stop time too far from shape.

A stop time entry that is a large distance away from the location of the shape in shapes.txt as defined by shape_dist_traveled values.

You can see more about this notice here.

tripCsvRowNumber (?) The row number of the faulty record from `trips.txt`. shapeId (?) The id of the shape that is referred to. tripId (?) The id of the trip that is referred to. stopTimeCsvRowNumber (?) The row number of the faulty record from `stop_times.txt`. stopId (?) The id of the stop that is referred to. stopName (?) The name of the stop that is referred to. match (?) Latitude and longitude pair of the location. geoDistanceToShape (?) Distance from stop to shape.
173 "SHAPEID_172" "215020" 7840 "502" "Via Galvani 78" [40.92952281549363,9.500752840330609] 296.93588125848373
173 "SHAPEID_172" "215020" 7841 "511" "Via Euclide fr. 12" [40.92952281549363,9.500752840330609] 384.9902365663804
stops_match_shape_out_of_order WARNING 1

stops_match_shape_out_of_order

Two stop entries are different than their arrival-departure order defined by shapes.txt.

This could indicate a problem with the location of the stops, the path of the shape, or the sequence of the stops for their trip.

You can see more about this notice here.

tripCsvRowNumber (?) The row number of the faulty record from `trips.txt`. shapeId (?) The id of the shape that is referred to. tripId (?) The id of the trip that is referred to. stopTimeCsvRowNumber1 (?) The row number of the first faulty record from `stop_times.txt`. stopId1 (?) The id of the first stop that is referred to. stopName1 (?) The name of the first stop that is referred to. match1 (?) Latitude and longitude pair of the first matching location. stopTimeCsvRowNumber2 (?) The row number of the second faulty record from `stop_times.txt`. stopId2 (?) The id of the second stop that is referred to. stopName2 (?) The name of the second stop that is referred to. match2 (?) Latitude and longitude pair of the second matching location.
173 "SHAPEID_172" "215020" 7840 "502" "Via Galvani 78" [40.92969210981254,9.497206784308272] 7839 "501" "Via Galvani 12A" [40.92952281625014,9.500752862179333]
trip_distance_exceeds_shape_distance_below_threshold WARNING 3

trip_distance_exceeds_shape_distance_below_threshold

The distance between the last shape point and last stop point is greater than 0 but less than the 11.1m threshold.

You can see more about this notice here.

tripId (?) The faulty record's trip id. shapeId (?) The faulty record's shape id. maxTripDistanceTraveled (?) The faulty record's trip max distance traveled. maxShapeDistanceTraveled (?) The faulty record's shape max distance traveled. geoDistanceToShape (?) The distance in meters between the shape and the stop.
"216389" "SHAPEID_380" 3.923 3.922 2.501526661004924
"216441" "SHAPEID_402" 22.217 22.216 3.7169047839484195
"216601" "SHAPEID_406" 18.056 18.054 3.7169047839484195