- Inleiding
- Python script gemeente_station_namen.py
- Python script station_data_naar_csv.py
- Python script samenvatting.py
- Voorbeeld voor genereren samenvatting van _Elshout.txt
- Voorbeelden van filteren opties
- Gegenereerd .kml bestand
- Voorbeeld van Google Maps op basis van .kml uitvoer
- Voorbeeld van gegenereerd PM2.5 .csv bestand: _Elshout.txt.pm25.csv
- Voorbeeld van gegenereerd PM10 .csv bestand: _Elshout.txt.pm10.csv
- Voorbeeld van gegenereerd gemiddeld PM2.5 .avg.csv bestand: _Elshout.txt.pm25.avg.csv
- Voorbeeld van gegenereerd gemiddeld PM10 .avg.csv bestand: _Elshout.txt.pm10.avg.csv
- Hoe Python, pakketten te installeren
In gemeente Heusden is er ook een samenmeten project en ik wilde weten in hoeverre de fijnstof uitstoot van PM10 en PM2.5 voldoet aan de WHO (World Health Organization) of EU richtlijnen en/of hoever we daarvan af zitten. Ik kon bij de RIVM wel historische data vinden, maar geen actuele informatie. Daarnaast wilde ik gebruik maken van gekalibreerde uurwaardes om zo te berekenen of een meetstation of een groep van meetstations op (lopende) jaarbasis wel of niet aan de richtlijnen voldoen. Daarom heb ik deze python scripts gemaakt en deze beschikbaar gesteld, zodat die door andere ook gebruikt kunnen worden. En eventuele verbeteringen aangebracht kunnen worden.
Er zijn 3 python scripts:
- gemeente_station_namen.py: hiermee kun je meetstation namen van een gemeente achterhalen
- station_data_naar_csv.py: hiermee kun je de uurwaardes van een meeststation of een groep van meetstations ophalen en toevoegen aan reeds beschikbare .csv bestanden
- samenvatting.py: genereert een samenvatting van de jaar waardes (en optioneel maand, week, dag) van een meetstation of groep van meetstations en schrijft deze ook naar een kml bestand, zodat je die in Google My Maps kunt importeren.
Voorbeeld van de resultaten van fijnstof van de jaren 2021 tot en met 2024 van gemeente Heusden kun je vinden op Google My Maps.
Python als programmeertaal heeft het voordeel dat het draait op Windows, Linux en Mac. De python scripts maken gebruik van https://api-samenmeten.rivm.nl/v1.0 voor het ophalen van de gegevens.
De andere python scripts gebruiken als invoer een bestand met lijst van meetstation namen. In plaats van de meetstation namen van een gemeente allemaal op te zoeken en over te typen, kun je dit script gebruiken als hulpmiddel.
Voer het volgende commando uit voor hulp:
python gemeente_station_namen.py
Gebruik : python gemeente_station_namen.py gemeente_code [debug]
Voorbeeld: python gemeente_station_namen.py 797
PARAMETER: gemeente_code
b.v. gemeente heusden is code 797
Zie GemeentenAlfabetisch2022.csv voor de codes voor iedere gemeente.
UITVOER : namen van stations
Zoek in GemeentenAlfabetisch2022.csv de gemeentecode op en voer dan het volgende commando uit voor een overzicht van stationnamen bij een gemeente.
python gemeente_station_namen.py 797
LTD_78470
LTD_75241
LTD_73365
LTD_73353
LTD_73155
LTD_69527
LTD_68565
LTD_67379
LTD_66698
LTD_66653
LTD_66012
LTD_65989
LTD_65769
LTD_65562
LTD_65341
LTD_65145
LTD_64753
LTD_64764
LTD_64544
LTD_64499
LTD_64345
LTD_64332
LTD_64160
LTD_64106
LTD_63545
GLB_1732427
LTD_63321
LTD_58544
LTD_58547
LTD_58098
LTD_57197
LTD_56098
LTD_56928
LTD_55358
LTD_56607
LTD_55458
LTD_55107
LTD_54636
LTD_54653
LTD_54447
LTD_54329
LTD_54311
LTD_54165
LTD_54087
LTD_51080
LTD_42281
LTD_41242
LTD_41345
Deze namen kun je in een bestand zetten, bijvoorbeeld _GemeenteHeusden.txt, die je in de volgende scripts als invoer gebruikt. Natuurlijk kun je hier meetstations uit verwijderen en/of toevoegen van bijvoorbeeld andere gemeentes.
Dit script update per meetstation uit het invoer bestand met meetstation namen een .csv bestand. De eerste keer zal deze alle data ophalen, de volgende keren zal deze nieuwe data toevoegen aan de .csv bestanden per meetstation.
Voer het volgende commando uit voor hulp:
python station_data_naar_csv.py
Gebruik : python station_data_naar_csv.py bestand_met_station_namen.txt [debug]
Voorbeeld: python station_data_naar_csv.py _GemeenteHeusden.txt
INVOER : bestand_met_station_namen.txt
UITVOER : voor iedere station in bestand_met_station_namen.txt schrijf .csv bestand
Opmerking: station namen van een gemeente kun je opvragen met:
python gemeente_station_namen.py gemeente_code
python station_data_naar_csv.py _GemeenteHeusden.txt
Ophalen station data voor GLB_1732427
Laatste datum locale tijd: 2024-01-27 11:00 -> iso8601 utc: 2024-01-27T10:00:00.000Z
Uitvoer csv bestand: GLB_1732427.csv
Ophalen data voor type: pm10_kal https://api-samenmeten.rivm.nl/v1.0/Datastreams(36530)/Observations
Ophalen data voor type: pm10 https://api-samenmeten.rivm.nl/v1.0/Datastreams(36529)/Observations
Ophalen data voor type: pm25_kal https://api-samenmeten.rivm.nl/v1.0/Datastreams(36528)/Observations
Ophalen data voor type: pm25 https://api-samenmeten.rivm.nl/v1.0/Datastreams(36527)/Observations
Geen nieuwe data gevonden sinds 2024-01-27T10:00:00.000Z
Ophalen station data voor LTD_56607
Laatste datum locale tijd: 2024-07-11 14:00 -> iso8601 utc: 2024-07-11T12:00:00.000Z
Uitvoer csv bestand: LTD_56607.csv
Ophalen data voor type: rh https://api-samenmeten.rivm.nl/v1.0/Datastreams(32216)/Observations
Ophalen data voor type: temp https://api-samenmeten.rivm.nl/v1.0/Datastreams(32215)/Observations
Ophalen data voor type: pm10_kal https://api-samenmeten.rivm.nl/v1.0/Datastreams(32214)/Observations
Ophalen data voor type: pm10 https://api-samenmeten.rivm.nl/v1.0/Datastreams(32213)/Observations
Ophalen data voor type: pm25_kal https://api-samenmeten.rivm.nl/v1.0/Datastreams(32212)/Observations
Ophalen data voor type: pm25 https://api-samenmeten.rivm.nl/v1.0/Datastreams(32211)/Observations
Toevoegen 92 resultaten aan csv bestand
Ophalen station data voor LTD_54329
Laatste datum locale tijd: 2024-07-11 14:00 -> iso8601 utc: 2024-07-11T12:00:00.000Z
Uitvoer csv bestand: LTD_54329.csv
Ophalen data voor type: rh https://api-samenmeten.rivm.nl/v1.0/Datastreams(30665)/Observations
Ophalen data voor type: temp https://api-samenmeten.rivm.nl/v1.0/Datastreams(30664)/Observations
Ophalen data voor type: pm10_kal https://api-samenmeten.rivm.nl/v1.0/Datastreams(30663)/Observations
Ophalen data voor type: pm10 https://api-samenmeten.rivm.nl/v1.0/Datastreams(30662)/Observations
Ophalen data voor type: pm25_kal https://api-samenmeten.rivm.nl/v1.0/Datastreams(30661)/Observations
Ophalen data voor type: pm25 https://api-samenmeten.rivm.nl/v1.0/Datastreams(30660)/Observations
Toevoegen 92 resultaten aan csv bestand
Ophalen station data voor LTD_57197
Laatste datum locale tijd: 2024-04-26 16:00 -> iso8601 utc: 2024-04-26T14:00:00.000Z
Uitvoer csv bestand: LTD_57197.csv
Ophalen data voor type: rh https://api-samenmeten.rivm.nl/v1.0/Datastreams(32584)/Observations
Ophalen data voor type: temp https://api-samenmeten.rivm.nl/v1.0/Datastreams(32583)/Observations
Ophalen data voor type: pm10_kal https://api-samenmeten.rivm.nl/v1.0/Datastreams(32582)/Observations
Ophalen data voor type: pm10 https://api-samenmeten.rivm.nl/v1.0/Datastreams(32581)/Observations
Ophalen data voor type: pm25_kal https://api-samenmeten.rivm.nl/v1.0/Datastreams(32580)/Observations
Ophalen data voor type: pm25 https://api-samenmeten.rivm.nl/v1.0/Datastreams(32579)/Observations
Geen nieuwe data gevonden sinds 2024-04-26T14:00:00.000Z
.....
datetime,pm10 kal,pm10,pm2.5 kal,pm2.5,rh%,temp,pm10 kal factor,pm2.5 kal factor
2021-11-21 13:00,6.942,8.88,2.574,1.76,68.32,12.33,0.782,1.462
2021-11-21 14:00,10.3,10.04,2.988,1.78,76.87,9.77,1.026,1.679
2021-11-21 15:00,8.32,6.42,,1.38,80.07,8.98,1.296,1.679
2021-11-21 16:00,10.2,7.47,2.828,1.38,77.91,8.64,1.365,2.049
2021-11-21 17:00,10.439,7.26,2.52,1.41,79.73,8.05,1.438,1.787
2021-11-21 18:00,8.82,7.01,2.048,1.63,80.76,7.18,1.258,1.256
2021-11-21 19:00,6.88,7.99,,2.5,81.3,6.54,0.861,1.256
2021-11-21 20:00,8.736,10.38,4.096,3.19,81.34,5.22,0.842,1.284
...
2024-09-26 07:00,4.256,3.16,1.314,1.77,100.0,14.1,1.347,0.742
2024-09-26 08:00,10.317,5.68,2.64,3.28,100.0,14.16,1.816,0.805
2024-09-26 09:00,8.091,8.67,6.256,4.61,100.0,14.28,0.933,1.357
2024-09-26 10:00,6.391,7.67,3.741,4.29,100.0,14.78,0.833,0.872
2024-09-26 11:00,9.62,6.5,3.844,3.12,100.0,15.62,1.480,1.232
2024-09-26 12:00,6.845,3.68,2.172,1.24,100.0,15.71,1.860,1.752
Dit script genereert een samenvatting per meetstation uit het invoer bestand met meetstation namen en gebruikt hiervoor de .csv bestanden die geupdate zijn uit het vorige script. Daarnaast wordt er ook een .kml bestand gemaakt, die je in Google My Maps kunt importeren. Om een mooie spreadsheet grafiek te maken, wordt er ook een PM2.5.csv en PM10.csv bestand gegenereerd.
Voer het volgende commando uit voor hulp:
python samenvatting.py
Onbekend invoer bestand:
Gebruik : python samenvatting.py STATION_LIJST.txt
Uitvoer : STATION_LIST.txt.kml (bestand in Google My Maps formaat)
STATION_LIST.txt.pm25.csv (PM2.5 per jaar per station in csv formaat)
STATION_LIST.txt.pm10.csv (PM10 per jaar per station in csv formaat)
STATION_LIST.txt.pm25.avg.csv (gemiddelde PM2.5 per jaar per station)
STATION_LIST.txt.pm10.avg.csv (gemiddelde PM10 per jaar per station)
Voorbeeld: python samenvatting.py _GemeenteHeusden.txt
Opties : [uur] [dag] [week] [maand] [j2000-3000] [m1-12] [d1-7] [u0-23]
Opm.1: Wilt u meer details zien, gebruik parameter uur/dag/week/maand
Opm.2: Wilt u alleen bepaalde jaren mee te nemen,
kunt u filteren met optie [j2000-3000]:
bijvoorbeeld alleen jaren 2021 tot en met 2022: j2021-2022
Opm.3: Wilt u alleen bepaalde maanden mee te nemen,
kunt u filteren met optie [m1-12]:
bijvoorbeeld alleen de maanden november tot en met maart: m11-3
Opm.4: Wilt u alleen bepaalde uren mee te nemen,
kunt u filteren met optie [u0-23]:
bijvoorbeeld alleen de uren van 18:00 tot en met 02:00: u18-2
Opm.5: Wilt u alleen bepaalde dagen mee te nemen,
kunt u filteren met optie [d1-7]:
1=ma, 2=di, 3=wo, 4=do, 5=vr, 6=za, 7=zo.
Voorbeeld voor weekenden, inclusief vrijdag: d5-7
Opm.6: station namen van een gemeente kan opgevraagd worden met tool:
python gemeente_station_namen.py gemeente_code
Opm.7: Voordat dit script gedraaid wordt, moeten de .csv bestanden voor
deze STATION_LIJST.txt gegenereerd zijn met:
python station_data_naar_csv.py STATION_LIJST.txt
python ..\samenvatting.py _Elshout.txt
Station, Periode, Datum, Info, PM10, (Min, Max, #WHO, #EU), PM2.5, (Min, Max, #WHO), Commentaar
LTD_58544, JAAR 269d/ 269d, 2022-12-31, 2022, 16.0, 2, 310, 6, 2, 10.8, 1, 140, 53, PM10 > WHO jaar 15; PM2.5 > WHO jaar 5
LTD_58544, JAAR 247d/ 247d, 2023-09-22, 2023, 16.6, 1, 128, 5, 4, 9.1, 1, 76, 33, PM10 > WHO jaar 15; PM2.5 > WHO jaar 5
LTD_58544, ALLES 516d/ 516d, , alles, 16.4, 0, 310, 6, 4, 10.1, 0, 140, 53, PM10 > WHO jaar 15; PM2.5 > WHO jaar 5
Station, Periode, Datum, Info, PM10, (Min, Max, #WHO, #EU), PM2.5, (Min, Max, #WHO), Commentaar
LTD_65562, JAAR 32d/ 32d, 2022-12-31, 2022, 15.7, 2, 57, 0, 0, 10.9, 0, 37, 10, PM10 > WHO jaar 15; PM2.5 > WHO jaar 5
LTD_65562, JAAR 341d/ 341d, 2023-12-31, 2023, 10.6, 0, 76, 0, 0, 5.1, 0, 53, 8, PM2.5 > WHO jaar 5
LTD_65562, JAAR 182d/ 182d, 2024-07-15, 2024, 9.3, 0, 90, 0, 0, 5.6, 0, 61, 7, PM2.5 > WHO jaar 5
LTD_65562, ALLES 556d/ 556d, , alles, 10.5, 0, 90, 0, 0, 5.7, 0, 61, 10, PM2.5 > WHO jaar 5
Station, Periode, Datum, Info, PM10, (Min, Max, #WHO, #EU), PM2.5, (Min, Max, #WHO), Commentaar
LTD_65341, JAAR 5d/ 5d, 2022-11-26, 2022, 32.9, 6, 85, 2, 0, 22.2, 6, 54, 6, PM10 > WHO jaar 15; PM2.5 > WHO jaar 5
LTD_65341, ALLES 5d/ 5d, , alles, 40.1, 0, 85, 2, 0, 29.4, 0, 54, 6, PM10 > WHO jaar 15 > EU jaar 40; PM2.5 > WHO jaar 5 > EU jaar 25
Station, Periode, Datum, Info, PM10, (Min, Max, #WHO, #EU), PM2.5, (Min, Max, #WHO), Commentaar
Gemiddelde, JAAR 307d/ 307d, , 2022, 16.3, 2, 310, 6, 2, 11.0, 0, 140, 53, PM10 > WHO jaar 15; PM2.5 > WHO jaar 5
Gemiddelde, JAAR 588d/ 588d, , 2023, 13.1, 0, 128, 5, 4, 6.8, 0, 76, 33, PM10 > WHO dag #5; PM2.5 > WHO jaar 5
Gemiddelde, JAAR 182d/ 182d, , 2024, 9.3, 0, 90, 0, 0, 5.6, 0, 61, 7, PM2.5 > WHO jaar 5
Gemiddelde, ALLES 1078d/ 1078d, , alles, 13.4, 0, 310, 6, 4, 7.8, 0, 140, 53, PM10 > WHO dag #6; PM2.5 > WHO jaar 5
Station, Periode, Datum, Info, PM10, (Min, Max, #WHO, #EU), PM2.5, (Min, Max, #WHO), Commentaar
Je kunt ook alleen een samenvatting genereren van een of meerdere volledige jaren, bijvoorbeeld 2021 en 2022:
python samenvatting.py j2021-2022 _GemeenteHeusden.txt
Je kunt ook alleen een samenvatting genereren van bepaalde maanden, bijvoorbeeld november tot en met maart:
python samenvatting.py m11-3 _GemeenteHeusden.txt
Je kunt ook alleen een samenvatting genereren van bepaalde uren, bijvoorbeeld van 18:00 tot en met 04:00:
python samenvatting.py u18-4 _GemeenteHeusden.txt
En je kunt de jaar-, maand- en uur-filters ook combineren.
python samenvatting.py j2021-2022 u18-4 m11-3 _GemeenteHeusden.txt
Het uitvoer kml bestand (de naam van je invoer bestand met extensie .kml, bijvoorbeeld _GemeenteHeusden.txt.kml) kun je importeren in Google My Maps.
Voorbeeld van de resultaten van fijnstof over 2021 tot en met 2024 van gemeente Heusden kun je hier vinden op Google My Maps.
Wanneer een meetstation boven de WHO waardes zit, dan wordt dit weergegeven als anders als (of als er geen meetdata voor laatste jaar is). De gemiddeldes van alle meetstations uit de lijst wordt ergens in het midden van de coördinaten weergegeven, boven de WHO waardes als anders als
Station,2022,2023,2024,Gemiddeld
LTD_58544,10.8,9.1,10.0
LTD_65341,22.2,22.2
LTD_65562,10.9,5.1,5.6,5.6
Hiermee kun je een mooie grafiek maken met per station de jaren gegroepeerd. Bijvoorbeeld:
Station,2022,2023,2024,Gemiddeld
LTD_58544,16.0,16.6,16.3
LTD_65341,32.9,32.9
LTD_65562,15.7,10.6,9.3,10.5
Hiermee kun je een mooie grafiek maken met per station de jaren gegroepeerd. Bijvoorbeeld:
Station,2022,2023,2024,Gemiddeld
Elshout,11.0,6.8,5.6,7.8
Hiermee kun je een mooie grafiek maken door per dorp/stad de jaren gegroepeerd (meerdere avg.csv bestanden samenvoegen). Bijvoorbeeld:
Station,2022,2023,2024,Gemiddeld
Drunen,11.2,7.2,7.6,8.4
Elshout,11.0,6.8,5.6,7.8
Hedikhuizen,8.6,6.0,8.3,6.8
Herpt,16.8,12.3,14.0,14.4
Heusden,12.4,7.5,7.2,8.7
Nieuwkuijk,9.6,6.2,6.6,7.1
OudHeusden,7.4,5.7,5.7,5.8
Vlijmen,8.7,6.4,6.9,7.0
GemeenteHeusden,10.7,6.9,7.3,8.0
Station,2022,2023,2024,Gemiddeld
Elshout,16.3,13.1,9.3,13.4
Hiermee kun je een mooie grafiek maken door per dorp/stad de jaren gegroepeerd (meerdere avg.csv bestanden samenvoegen). Bijvoorbeeld:
Station,2022,2023,2024,Gemiddeld
Drunen,16.3,13.4,12.0,13.9
Elshout,16.3,13.1,9.3,13.4
Hedikhuizen,13.6,12.5,12.7,12.7
Herpt,19.5,16.9,15.8,17.7
Heusden,18.7,13.0,10.7,13.9
Nieuwkuijk,15.5,12.3,11.4,12.8
OudHeusden,14.3,12.3,11.1,11.9
Vlijmen,13.1,12.2,11.3,12.0
GemeenteHeusden,15.7,12.9,11.7,13.3
Uitleg voor iemand die geen kennis heeft van Python. Ik weet niet welke computer en operating systeem u heeft.
U moet Python 3.9 of hoger installeren. Ik heb Python 3.9.13 geïnstalleerd. Hier vindt u meer informatie over het installeren van Python
Waarschijnlijk zijn sommige pakketten die nodig zijn voor samenmeten-rivm-tools niet geïnstalleerd (foutmeldingen). Meer informatie over het installeren van Python-pakketten Ik heb de volgende pakketten geïnstalleerd (gebruik bijvoorbeeld python -m pip install "package_name"), zie requirements.txt
python_dateutil==2.8.2