fintraffic — Enhanced Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-06-11T12:30:46Z,
for the dataset file:///shared/fintraffic_d33fd9c9.zip. No country code was provided.

Use this report alongside our documentation.

A new version of the Canonical GTFS Schedule validator is available! Please update to get the latest/best validation results.

Summary

Agencies included


Feed Info


Publisher Name:
Busmaps.com
Publisher URL:
https://busmaps.com
Feed Language:
Finnish
Feed Start Date:
2014-07-01
Feed End Date:
2027-12-31

Files included


  1. agency.txt
  2. calendar.txt
  3. calendar_dates.txt
  4. fare_attributes.txt
  5. fare_rules.txt
  6. feed_info.txt
  7. routes.txt
  8. shapes.txt
  9. stop_times.txt
  10. stops.txt
  11. transfers.txt
  12. translations.txt
  13. trips.txt

Counts


  • Agencies: 185
  • Blocks: 2545
  • Routes: 4869
  • Shapes: 9184
  • Stops: 66851
  • Trips: 413992

Specification Compliance report

664455 notices reported (281 errors, 663772 warnings, 402 infos)

Notice Code Severity Total
block_trips_with_overlapping_stop_times ERROR 281

block_trips_with_overlapping_stop_times

Trips with the same block id have overlapping stop times.

You can see more about this notice here.

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

csvRowNumberA (?) The row number from `trips.txt` of the first faulty trip. tripIdA (?) The id of first faulty trip. serviceIdA (?) The service id of the first faulty trip. csvRowNumberB (?) The row number from `trips.txt` of the second faulty trip. tripIdB (?) The id of the other faulty trip. serviceIdB (?) The service id of the other faulty trip. blockId (?) The `trips.block_id` of the overlapping trip. intersection (?) The overlapping period.
19282 "1029-11389_121_19994_17375090" "1029-11389_121_19994" 18796 "1029-11389_119_20476_16535742" "1029-merged_816046ce309abee7c7db" "11389_3502" "20260805"
23209 "1029-11389_120_18753_17848282" "1029-10000_1001H5_20260615_20260806_JP" 22771 "1029-11389_119_19216_17848174" "1029-merged_adbf0b908752e42f8b1f" "11389_0504" "20260620"
22771 "1029-11389_119_19216_17848174" "1029-merged_adbf0b908752e42f8b1f" 23257 "1029-11389_120_18753_17848382" "1029-10000_1001H5_20260615_20260806_JP" "11389_0504" "20260620"
23211 "1029-11389_120_18753_17848286" "1029-10000_1001H5_20260615_20260806_JP" 22775 "1029-11389_119_19216_17848182" "1029-merged_adbf0b908752e42f8b1f" "11389_0505" "20260620"
22775 "1029-11389_119_19216_17848182" "1029-merged_adbf0b908752e42f8b1f" 23258 "1029-11389_120_18753_17848386" "1029-10000_1001H5_20260615_20260806_JP" "11389_0505" "20260620"
23259 "1029-11389_120_18753_17848388" "1029-10000_1001H5_20260615_20260806_JP" 22779 "1029-11389_119_19216_17848190" "1029-merged_adbf0b908752e42f8b1f" "11389_0503" "20260620"
22779 "1029-11389_119_19216_17848190" "1029-merged_adbf0b908752e42f8b1f" 23217 "1029-11389_120_18753_17848298" "1029-10000_1001H5_20260615_20260806_JP" "11389_0503" "20260620"
23748 "1029-11389_121_20321_17848650" "1029-11389_121_19970" 23231 "1029-11389_120_18753_17848326" "1029-merged_4069ebeccd5d7a762055" "11389_0501" "20260808"
23231 "1029-11389_120_18753_17848326" "1029-merged_4069ebeccd5d7a762055" 23812 "1029-11389_121_20321_17848780" "1029-11389_121_19970" "11389_0501" "20260808"
9286 "1029-11389_119_20534_16364194" "1029-merged_a6ee01859794767b6d0d" 9933 "1029-11389_121_19995_17721050" "1029-11389_121_19994" "11389_1802" "20260805"
9868 "1029-11389_121_19995_17720846" "1029-11389_121_19994" 9294 "1029-11389_119_20534_16364332" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9294 "1029-11389_119_20534_16364332" "1029-merged_a6ee01859794767b6d0d" 9936 "1029-11389_121_19995_17721056" "1029-11389_121_19994" "11389_1802" "20260805"
9871 "1029-11389_121_19995_17720852" "1029-11389_121_19994" 9297 "1029-11389_119_20534_16364338" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9297 "1029-11389_119_20534_16364338" "1029-merged_a6ee01859794767b6d0d" 9939 "1029-11389_121_19995_17721062" "1029-11389_121_19994" "11389_1802" "20260805"
9874 "1029-11389_121_19995_17720858" "1029-11389_121_19994" 9300 "1029-11389_119_20534_16364344" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9300 "1029-11389_119_20534_16364344" "1029-merged_a6ee01859794767b6d0d" 9942 "1029-11389_121_19995_17721068" "1029-11389_121_19994" "11389_1802" "20260805"
9877 "1029-11389_121_19995_17720864" "1029-11389_121_19994" 9303 "1029-11389_119_20534_16364350" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9303 "1029-11389_119_20534_16364350" "1029-merged_a6ee01859794767b6d0d" 9945 "1029-11389_121_19995_17721074" "1029-11389_121_19994" "11389_1802" "20260805"
9880 "1029-11389_121_19995_17720870" "1029-11389_121_19994" 9306 "1029-11389_119_20534_16364356" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9306 "1029-11389_119_20534_16364356" "1029-merged_a6ee01859794767b6d0d" 9948 "1029-11389_121_19995_17721080" "1029-11389_121_19994" "11389_1802" "20260805"
9883 "1029-11389_121_19995_17720876" "1029-11389_121_19994" 9309 "1029-11389_119_20534_16364362" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9309 "1029-11389_119_20534_16364362" "1029-merged_a6ee01859794767b6d0d" 9951 "1029-11389_121_19995_17721086" "1029-11389_121_19994" "11389_1802" "20260805"
9886 "1029-11389_121_19995_17720882" "1029-11389_121_19994" 9312 "1029-11389_119_20534_16364368" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9312 "1029-11389_119_20534_16364368" "1029-merged_a6ee01859794767b6d0d" 9954 "1029-11389_121_19995_17721092" "1029-11389_121_19994" "11389_1802" "20260805"
9889 "1029-11389_121_19995_17720888" "1029-11389_121_19994" 9315 "1029-11389_119_20534_16364374" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9315 "1029-11389_119_20534_16364374" "1029-merged_a6ee01859794767b6d0d" 9957 "1029-11389_121_19995_17721098" "1029-11389_121_19994" "11389_1802" "20260805"
9957 "1029-11389_121_19995_17721098" "1029-11389_121_19994" 9376 "1029-11389_119_20534_16364622" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9892 "1029-11389_121_19995_17720894" "1029-11389_121_19994" 9318 "1029-11389_119_20534_16364380" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9318 "1029-11389_119_20534_16364380" "1029-merged_a6ee01859794767b6d0d" 9960 "1029-11389_121_19995_17721104" "1029-11389_121_19994" "11389_1802" "20260805"
9960 "1029-11389_121_19995_17721104" "1029-11389_121_19994" 9379 "1029-11389_119_20534_16364628" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9927 "1029-11389_121_19995_17721030" "1029-11389_121_19994" 9336 "1029-11389_119_20534_16364416" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9336 "1029-11389_119_20534_16364416" "1029-merged_a6ee01859794767b6d0d" 9978 "1029-11389_121_19995_17721140" "1029-11389_121_19994" "11389_1802" "20260805"
9978 "1029-11389_121_19995_17721140" "1029-11389_121_19994" 9397 "1029-11389_119_20534_16364664" "1029-merged_a6ee01859794767b6d0d" "11389_1802" "20260805"
9295 "1029-11389_119_20534_16364334" "1029-merged_a6ee01859794767b6d0d" 9870 "1029-11389_121_19995_17720850" "1029-11389_121_19994" "11389_1803" "20260805"
9298 "1029-11389_119_20534_16364340" "1029-merged_a6ee01859794767b6d0d" 9873 "1029-11389_121_19995_17720856" "1029-11389_121_19994" "11389_1803" "20260805"
9301 "1029-11389_119_20534_16364346" "1029-merged_a6ee01859794767b6d0d" 9876 "1029-11389_121_19995_17720862" "1029-11389_121_19994" "11389_1803" "20260805"
9304 "1029-11389_119_20534_16364352" "1029-merged_a6ee01859794767b6d0d" 9879 "1029-11389_121_19995_17720868" "1029-11389_121_19994" "11389_1803" "20260805"
9307 "1029-11389_119_20534_16364358" "1029-merged_a6ee01859794767b6d0d" 9882 "1029-11389_121_19995_17720874" "1029-11389_121_19994" "11389_1803" "20260805"
9310 "1029-11389_119_20534_16364364" "1029-merged_a6ee01859794767b6d0d" 9885 "1029-11389_121_19995_17720880" "1029-11389_121_19994" "11389_1803" "20260805"
9313 "1029-11389_119_20534_16364370" "1029-merged_a6ee01859794767b6d0d" 9888 "1029-11389_121_19995_17720886" "1029-11389_121_19994" "11389_1803" "20260805"
9316 "1029-11389_119_20534_16364376" "1029-merged_a6ee01859794767b6d0d" 9891 "1029-11389_121_19995_17720892" "1029-11389_121_19994" "11389_1803" "20260805"
9891 "1029-11389_121_19995_17720892" "1029-11389_121_19994" 9377 "1029-11389_119_20534_16364624" "1029-merged_a6ee01859794767b6d0d" "11389_1803" "20260805"
9377 "1029-11389_119_20534_16364624" "1029-merged_a6ee01859794767b6d0d" 9959 "1029-11389_121_19995_17721102" "1029-11389_121_19994" "11389_1803" "20260805"
9319 "1029-11389_119_20534_16364382" "1029-merged_a6ee01859794767b6d0d" 9894 "1029-11389_121_19995_17720898" "1029-11389_121_19994" "11389_1803" "20260805"
9894 "1029-11389_121_19995_17720898" "1029-11389_121_19994" 9380 "1029-11389_119_20534_16364630" "1029-merged_a6ee01859794767b6d0d" "11389_1803" "20260805"
9380 "1029-11389_119_20534_16364630" "1029-merged_a6ee01859794767b6d0d" 9962 "1029-11389_121_19995_17721108" "1029-11389_121_19994" "11389_1803" "20260805"
9334 "1029-11389_119_20534_16364412" "1029-merged_a6ee01859794767b6d0d" 9926 "1029-11389_121_19995_17721028" "1029-11389_121_19994" "11389_1803" "20260805"
9926 "1029-11389_121_19995_17721028" "1029-11389_121_19994" 9395 "1029-11389_119_20534_16364660" "1029-merged_a6ee01859794767b6d0d" "11389_1803" "20260805"
9395 "1029-11389_119_20534_16364660" "1029-merged_a6ee01859794767b6d0d" 9977 "1029-11389_121_19995_17721138" "1029-11389_121_19994" "11389_1803" "20260805"
9337 "1029-11389_119_20534_16364418" "1029-merged_a6ee01859794767b6d0d" 9907 "1029-11389_121_19995_17720930" "1029-11389_121_19994" "11389_1803" "20260805"
duplicate_route_name WARNING 4

duplicate_route_name

Two distinct routes have either the same route_short_name, the same route_long_name, or the same combination of route_short_name and route_long_name.

All routes of the same route_type with the same agency_id should have unique combinations of route_short_name and route_long_name.

Note that there may be valid cases where routes have the same short and long name, e.g., if they serve different areas. However, different directions must be modeled as the same route.

Example of bad data:

route_id route_short_name route_long_name
route1 U1 Southern
route2 U1 Southern

You can see more about this notice here.

csvRowNumber1 (?) The row number of the first occurrence. routeId1 (?) The id of the the first occurrence. csvRowNumber2 (?) The row number of the other occurrence. routeId2 (?) The id of the the other occurrence. routeShortName (?) Common `routes.route_short_name`. routeLongName (?) Common `routes.route_long_name`. routeTypeValue (?) Common `routes.route_type`. agencyId (?) Common `routes.agency_id`.
2525 "1029-138504" 2526 "1029-138505" "" "Kuopio - Varkaus" 3 "1029-1083"
2532 "1029-138516" 2534 "1029-138519" "" "Varkaus - Kuopio" 3 "1029-1083"
2235 "1029-106029" 4433 "1029-341023" "440" "Joensuu - Juuka - Nurmes" 3 "1029-1061"
2343 "1029-115321" 4628 "1029-348682" "" "Helsinki - Hyvinkää" 3 "1029-1101"
expired_calendar WARNING 212

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 212 affected records are displayed below.

csvRowNumber (?) The row of the faulty record. serviceId (?) The service id of the faulty record.
3 "1029-011610c854028f08dc5b"
6 "1029-10000_1001H5_20260608_20260614_8K"
7 "1029-10000_1001H5_20260608_20260614_Ke"
17 "1029-10000_1001H7_20260608_20260614_7K"
29 "1029-10000_1016_20260608_20260614_Ma"
31 "1029-10000_1016_20260608_20260614_Ti"
196 "1029-10008_Gymnaestrada la"
197 "1029-10008_Gymnaestrada pe"
198 "1029-10008_Gymnaestrada su"
199 "1029-10008_Gymnaestrada to"
221 "1029-10010_Kaupunkiliikenne kesä VEKKA"
268 "1029-10016_talvi arki lomapäivät 2025-2026"
448 "1029-10214_2025 - 2026 Lempi TO"
449 "1029-10214_2025-2026 La 22122025 alkaen"
450 "1029-10214_2025-2026 MaTo KP 20260407 alkaen"
451 "1029-10214_2025-2026 Pe KP 20260407 alkaen"
452 "1029-10214_2025-2026 Su 22122025 alkaen"
465 "1029-10214_490 MaPe TALVI2526"
466 "1029-10214_7B lisälähdöt Ma-Pe KP 20261602 alkaen"
474 "1029-10214_Kulkunen TI 20260129 alkaen"
529 "1029-10301_1008"
530 "1029-10301_1010"
531 "1029-10301_1011"
532 "1029-10301_1026"
533 "1029-10301_1027"
534 "1029-10301_1028"
535 "1029-10301_1030"
536 "1029-10301_1036"
537 "1029-10301_1062"
538 "1029-10301_1068"
539 "1029-10301_1069"
540 "1029-10301_1097"
541 "1029-10301_1098"
542 "1029-10301_1099"
543 "1029-10301_1100"
544 "1029-10301_1120"
545 "1029-10301_1137"
546 "1029-10301_1167"
547 "1029-10301_1168"
548 "1029-10301_1169"
549 "1029-10301_1181"
550 "1029-10301_1182"
551 "1029-10301_1190"
552 "1029-10301_1199"
553 "1029-10301_1201"
554 "1029-10301_1225"
555 "1029-10301_1226"
556 "1029-10301_1238"
557 "1029-10301_1247"
558 "1029-10301_1248"
fast_travel_between_far_stops WARNING 3

fast_travel_between_far_stops

A transit vehicle moves too fast between two far stops.

Two stops are considered "far" if they are more than 10 km apart. This normally indicates a more serious problem than too fast travel between consecutive stops.

The speed threshold depends on route type and are the same as fast_travel_between_consecutive_stops.

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.
366100 "1029-10156_7512" "1029-25544" 157.5068517462525 10.5004567830835 11364641 28 "1029-376669" "Puoliväli I" "16:13:00" 11364652 39 "1029-376691" "Hirvosenmäki I" "16:16:00"
2716 "1029-10008_ELY_S_2026_480S_0_151000_151000_0" "1029-107059" 154.29511211684985 10.28634080778999 130235 54 "1029-321752" "Kauniinjärvi I" "16:11:00" 130243 62 "1029-321767" "Ylätie P" "16:14:00"
366101 "1029-10156_7513" "1029-25546" 150.60583150323583 15.060583150323582 11364670 5 "1029-350771" "Muikunlahdentie P" "15:20:00" 11364684 19 "1029-376676" "Keitelepohja L" "15:25:00"
mixed_case_recommended_field WARNING 191

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 191 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_short_name" "246kt" 94
"routes.txt" "route_short_name" "349bk" 114
"routes.txt" "route_short_name" "35bk" 985
"routes.txt" "route_short_name" "454ax" 1415
"routes.txt" "route_short_name" "2ap" 1896
"routes.txt" "route_short_name" "2ip" 1897
"routes.txt" "route_short_name" "10me" 1953
"routes.txt" "route_short_name" "4tl" 2109
"routes.txt" "route_short_name" "192km" 2953
"routes.txt" "route_short_name" "192km" 2954
"routes.txt" "route_short_name" "192km" 2955
"routes.txt" "route_short_name" "194vk" 2969
"routes.txt" "route_short_name" "35av" 4352
"routes.txt" "route_short_name" "31ak" 4665
"stops.txt" "stop_name" "DHL etelä" 4624
"stops.txt" "stop_name" "DHL pohjoinen" 4625
"stops.txt" "stop_name" "DHL etelä" 4763
"stops.txt" "stop_name" "DHL pohjoinen" 4764
"stops.txt" "stop_name" "Y-tien vaihtopysäkki I" 14973
"stops.txt" "stop_name" "Y-tien risteys I" 15452
"stops.txt" "stop_name" "Y-tien risteys L" 15453
"stops.txt" "stop_name" "TV-masto I" 18819
"stops.txt" "stop_name" "TV-masto L" 18820
"stops.txt" "stop_name" "III hautausmaa I" 27006
"stops.txt" "stop_name" "III hautausmaa L" 27007
"stops.txt" "stop_name" "E-P:n opisto th L" 28992
"stops.txt" "stop_name" "E-P:n opisto th I" 28993
"stops.txt" "stop_name" "ABC piha" 34100
"stops.txt" "stop_name" "S-market 8-tie P" 35586
"stops.txt" "stop_name" "S-market 8-tie E" 35587
"stops.txt" "stop_name" "linja-autoasema" 35597
"stops.txt" "stop_name" "linja-autoasema" 36201
"stops.txt" "stop_name" "linja-autoasema" 36958
"stops.txt" "stop_name" "asema-aukio" 37382
"stops.txt" "stop_name" "linja-autoasema" 39021
"stops.txt" "stop_name" "Y-tien vaihtopysäkki L" 39624
"stops.txt" "stop_name" "linja-autoasema" 40236
"stops.txt" "stop_name" "SAK-opisto" 42991
"stops.txt" "stop_name" "NYK portti" 43183
"stops.txt" "stop_name" "linja-autoasema" 43260
"stops.txt" "stop_name" "UPM pääportti I" 44515
"stops.txt" "stop_name" "UPM pääportti L" 44516
"stops.txt" "stop_name" "UPM konttori I" 44517
"stops.txt" "stop_name" "ABC piha" 45041
"stops.txt" "stop_name" "S-market sisäpiha" 47035
"stops.txt" "stop_name" "4H-gården" 49470
"stops.txt" "stop_name" "4H-gården" 49471
"stops.txt" "stop_name" "GE-huset" 49545
"stops.txt" "stop_name" "GE-huset" 49546
"stops.txt" "stop_name" "pv" 50169
non_ascii_or_non_printable_char WARNING 662298

non_ascii_or_non_printable_char

Non ascii or non printable char in ID field.

A value of a field with type ID contains non ASCII or non printable characters. This is not recommended.

You can see more about this notice here.

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

filename (?) Name of the faulty file. csvRowNumber (?) Row number of the faulty record. columnName (?) Name of the column where the error occurred. fieldValue (?) Faulty value.
"calendar.txt" 168 "service_id" "1029-10007_2026 kesä_0_ma-pe_alkaa_2026-08-05"
"calendar.txt" 169 "service_id" "1029-10007_2026 kesä_0_ma-pe_loppuu_2026-08-04"
"calendar.txt" 170 "service_id" "1029-10007_2026 kesä_0_ma-to"
"calendar.txt" 171 "service_id" "1029-10007_2026 kesä_1_ma"
"calendar.txt" 172 "service_id" "1029-10007_2026 kesä_2_ti"
"calendar.txt" 173 "service_id" "1029-10007_2026 kesä_3_ke"
"calendar.txt" 174 "service_id" "1029-10007_2026 kesä_4_to"
"calendar.txt" 175 "service_id" "1029-10007_2026 kesä_5_pe"
"calendar.txt" 176 "service_id" "1029-10007_2026 kesä_7_su"
"calendar.txt" 189 "service_id" "1029-10008_ELY KESÄ M-P 2026"
"calendar.txt" 190 "service_id" "1029-10008_ELY KESÄ MP 2026"
"calendar.txt" 203 "service_id" "1029-10008_Kesäaikataulu_La"
"calendar.txt" 204 "service_id" "1029-10008_Kesäaikataulu_M-P"
"calendar.txt" 205 "service_id" "1029-10008_Kesäaikataulu_P"
"calendar.txt" 206 "service_id" "1029-10008_Kesäaikataulu_Su"
"calendar.txt" 220 "service_id" "1029-10009_Vaajakoski lisäauto MA ja TO"
"calendar.txt" 221 "service_id" "1029-10010_Kaupunkiliikenne kesä VEKKA"
"calendar.txt" 222 "service_id" "1029-10010_Kesäliikenne 2026 SL"
"calendar.txt" 224 "service_id" "1029-10010_SOTKATTI Kesäarki 2026"
"calendar.txt" 225 "service_id" "1029-10011_2026 KESÄ Hamina Ma ja Ke"
"calendar.txt" 226 "service_id" "1029-10011_2026 KESÄ Hamina Ma ja TO"
"calendar.txt" 227 "service_id" "1029-10011_2026 KESÄ Hamina Ti ja Pe"
"calendar.txt" 228 "service_id" "1029-10011_2026 KESÄ Hamina Ti ja To"
"calendar.txt" 229 "service_id" "1029-10011_2026 KESÄ Kotka MA,KE&PE"
"calendar.txt" 230 "service_id" "1029-10011_2026 KESÄ Kotka TI,KE&TO"
"calendar.txt" 231 "service_id" "1029-10011_2026 KESÄ Linja 1 (Ma-Pe) 4.8 asti"
"calendar.txt" 233 "service_id" "1029-10012_2026_Kesä_Ma-To"
"calendar.txt" 234 "service_id" "1029-10012_2026_Kesä_Pe"
"calendar.txt" 235 "service_id" "1029-10012_2026_Kuopiorock_lisät_la"
"calendar.txt" 236 "service_id" "1029-10012_2026_Kuopiorock_lisät_pe"
"calendar.txt" 239 "service_id" "1029-10013_Imatra La Kesä"
"calendar.txt" 241 "service_id" "1029-10013_Imatra M-P Kesä"
"calendar.txt" 243 "service_id" "1029-10013_Imatra Su Kesä"
"calendar.txt" 245 "service_id" "1029-10013_M-P Kesä"
"calendar.txt" 249 "service_id" "1029-10013_Su Kesä"
"calendar.txt" 265 "service_id" "1029-10016_kesä arki 2026"
"calendar.txt" 266 "service_id" "1029-10016_kesä viikonloppu 2026"
"calendar.txt" 267 "service_id" "1029-10016_kesä Winnova extra 2026"
"calendar.txt" 268 "service_id" "1029-10016_talvi arki lomapäivät 2025-2026"
"calendar.txt" 284 "service_id" "1029-10019_Lifti_kesäkausi_La"
"calendar.txt" 285 "service_id" "1029-10019_Lifti_kesäkausi_Su"
"calendar.txt" 290 "service_id" "1029-10040_Livi_KOULPV_M_P_Pöytyä_2"
"calendar.txt" 291 "service_id" "1029-10040_Livi_KOULPV_M_P_Pöytyä_3"
"calendar.txt" 294 "service_id" "1029-10087_Livi_TALVI_M_P_Pudasjärvi"
"calendar.txt" 453 "service_id" "1029-10214_2026 Kesä La"
"calendar.txt" 454 "service_id" "1029-10214_2026 Kesä La Hämeenkatu"
"calendar.txt" 455 "service_id" "1029-10214_2026 Kesä Ma-To Hämeenkatu"
"calendar.txt" 456 "service_id" "1029-10214_2026 Kesä MaTo"
"calendar.txt" 457 "service_id" "1029-10214_2026 Kesä Pe"
"calendar.txt" 458 "service_id" "1029-10214_2026 Kesä Pe Hämeenkatu"