Home-Assistant integration of 'Abfall.IO' waste collection dates & schedule

you dont need to, you just need to replace the “pdf” or “ics” in the request URL with “csv”.

I have to use an other site for collecting the dates and there is only the possibility to get the dates as pdf / ics.

Example:
https://www.awigo.de/index.php?eID=awigoCalendar&calendar[method]=getPDFfile&calendar[locationID]=648892001&calendar[cityID]=5337001&calendar[address_full_street]=Heideweg%202&calendar[address_full_cityplz]=Belm%20(49191)

I tried to manipulate the URL and it seems you cant get CSV files with this service.

I think its quite hard to parse PDF’s. I reckon its easier you parse the ICS file. But you need to write a custom parser for this.

Sorry I cant help you here.

Thanks, no problem. I already implemented a solution for my waste collection (via google calendar). Working fine but an addon with collecting data from a web url is much better than manually adding the ics to the calendar.
When I have some time I am going to parse the ICS file…

Hi Tom,

I came to the same conclusion and was able to adapt the component to use the json I recieved via the Ajax request. Component is working fine now.

Thanks for the help,
Nils

I had a strange bug. The order of the columns in the response no longer matches the payload. Therefore I had wrong data. I fixed it by saving the index from the first line in a dictionary.
If someone else has the same problem:

        rowCounter = 0
        columns = None
        gelberSack = []
        restAbfall = []
        papierTonne = []
        bioTonne = []
        problemStoffMobil = []
        
        for row in reader:
            if rowCounter == 0:
                columns = {k:row.index(k) for k in row}
            else:
                if (row[columns["Biotonne"]] != ""):
                    bioTonne.append(datetime.strptime(row[columns["Biotonne"]], "%d.%m.%Y"))

                if (row[columns["Restmülltonne"]] != ""):
                    restAbfall.append(datetime.strptime(row[columns["Restmülltonne"]], "%d.%m.%Y"))

                if (row[columns["Papiertonne"]] != ""):
                    papierTonne.append(datetime.strptime(row[columns["Papiertonne"]], "%d.%m.%Y"))

                if (row[columns["Gelber Sack"]] != ""):
                    gelberSack.append(datetime.strptime(row[columns["Gelber Sack"]], "%d.%m.%Y"))

                if (row[columns["Problemstoffmobil"]] != ""):
                    problemStoffMobil.append(datetime.strptime(row[columns["Problemstoffmobil"]], "%d.%m.%Y"))                        

            rowCounter = rowCounter + 1

Thanks for publishing this. I changed the code at home with your recommendation. Just in case the change the order of values in Landshut too :slight_smile: works like a charm.

if its okay, i publish the changed code on my blog.

cheers
Tom

Of course :slight_smile:

I changed the date comparisons from

if nextDate > datetime.now():

to

if nextDate.date() >= datetime.now().date():

It showed me the next date when the actual date is today on HA restart.

Thanks for this component!

Hi,

I have a google calendar integration with the dates. Is it possible to modify your module to use this google calendar? Right now I have 3 entities from the google calendar with dates but I also want to see how many days and so on.

The Date of one of these entities in found in an attribute. For Example the entity name is calendar.abfall_papier and in the atribute “start_time” is the date.

Thanks and cheers

alex

Hello,

I am pretty new to HA and just found this integration. My town works with the MyMüll App but also has a script on the homepage to get to the collection dates. Could anyone help me to find out if this website could be integrated and how:
https://abfallservice.kreis-hoexter.de/kundencenter/abfall-kalender/index.html

Thanks for your help
Berni

Hi Tom and everyone who contributed to this script,

I just wanted to say thank you for sharing this! :slight_smile:

One thing had me confused at first, though. The names for the different types of waste are not fixed. I had to rename Restmüll to Hausmüll in order to get the information I wanted. :crazy_face:

Here’s a link to my repo:

Hello everyone, can anyone tell me how to get to the dates “Kommune, Bezirk, Straße, …” come? i have received the following applink from abfall. io

I looked at the website of my local waste collector, which uses abfall.io, filled out the input selects an check boxes and then right click and ‘Inspect Element’ on the Elements in Firefox.


Was a lot of trial and error.
Good luck! :crossed_fingers:

Hello,

did i need a init.py file and how can i find it ?

This is what i have:

(hass) homeassi:~$ cat .homeassistant/custom_components/abfall_wabue/__init__.py 
DOMAIN = "abfall_wabue"

Hi Ingo,

i uploaded everything to my git, you can take a look there:

https://git.relict.de/tom/ha_abfall_landshut

Cheers
Tom

Hello everybody,

thanks for the work - I would very much like to use it too. Unfortunately I fail because I can’t find the ID for my district. If I look at abfall.io, my district is supported. but if i search on the official site, i only get a PDF or ics for download. Examine elements etc. doesn’t work or I can’t get the district ID. It’s about the community of Pleidelsheim near Ludwigsburg. The waste disposal company is called AVL. Can someone help me please?

Thank you very much
Frank

1 Like

Hi Frank,

are you talking about this service?
https://www.avl-ludwigsburg.de/privatkunden/termine/abfallkalender/abfallkalender/suche/

If yes: I couldnt find any link to abfall.io services. It seems you directly download the waste-collecting-schdules from their Typo3 file storage. So the approach which i was using doesnt work here.

Sorry

Cheers
Tom

1 Like

Hi Tom, yes correct, thats this service. Ok, so not good for me and cant use this solution here. But thanks anyway for your help.