I am trying to think about how to capture and display the details of my electricity monitoring system, teh OWL Intuition. It outputs a UDP string which I can capture through an Item;
I have been reading up on the XLST construct and think I need to use that in some fashion but I just cannot get it to do anything. Do I set this formatting up through this binding at the item or in a rule to do the processing of the string?
I am still a bit of a novice at this but I am eager to learn and improve!
Ultimately I want to get his into a HABPanel widget to show the electricity consumption and into my influxDB persistence so I can track over time but wanted to work on getting the information in the right format first!
The XPATH you are already trying to use is probably the best approach.
The only problem is the path you are trying to use is incorrect. XML is hierarchical. When you see an open tag (e.g. <electricity>) everything that occurs after that until the closing tag (e.g. </electricity>) is inside it. It is a lot like folders/directory structure on your hardrive on your computer.
The xpath is like the path to a folder on your hard drive.
Furthermore, element names cannot have a space. The stuff after the space is an attribute (e.g. “id=12345678912C” is an attribute on the “electricity” element. In xpath you reference an attribute using different syntax.
I have no idea what information you need form this XML. If you only need one piece of information then you can use the XPATH to retrieve just that piece of data. For example, to get the value of curr from chan 0:
XPATH(//electricity/chan[@id=0]/curr)
I highly recommend going through the XML and XPATH tutorials at W3 schools.
However, if there is more than one piece of information you need from this one message, you will need to create a Rule and extract each piece of information individually from the message and postUpdate or sendCommand them. You can still use XPATH and the transform action
That is great and thank you for the steer towards the tutorials I will get on those now. I will have a play with the XPATH to extract each bit of info I need.
Again thanks and I will report back success or not.
I have modified the TestSensor Item entry as follows and no dice I am afraid. I am still getting the whole string captured against the string variable in the item.
Also tried the rule based approach and it throws exceptions. I checked the XPATH syntax in my code to make sure I hadnt mis typed etc. on this free checker (Free Online XPath Tester / Evaluator - FreeFormatter.com) and that come sout good so there is something a miss with the openhab2 transform end a config I am missing.
XPATH is installed via PaperUI not got any .cfg file for it as far as I can see.
Not all xpath implementations are always the same. There might be a problem with the way it handles the attribute. Search StackOverflow for “xpath select attribute” and you will find lots of postings with several different variations.
Always always post the exceptions. We have no idea what could be going on without knowing what they are.
Got some more info in these exceptions after an openhab2 update.
org.openhab.core.transform.TransformationException: transformation throws exceptions
at org.openhab.core.transform.TransformationHelper$TransformationServiceDelegate.transform(TransformationHelper.java:62)[194:org.openhab.core.compat1x:2.1.0]
at org.openhab.binding.tcp.protocol.internal.UDPBinding.transformResponse(UDPBinding.java:263)[193:org.openhab.binding.tcp:1.10.0]
at org.openhab.binding.tcp.protocol.internal.UDPBinding.parseBuffer(UDPBinding.java:159)[193:org.openhab.binding.tcp:1.10.0]
at org.openhab.binding.tcp.AbstractDatagramChannelBinding.parseChanneledBuffer(AbstractDatagramChannelBinding.java:1014)[193:org.openhab.binding.tcp:1.10.0]
at org.openhab.binding.tcp.AbstractDatagramChannelBinding.execute(AbstractDatagramChannelBinding.java:1551)[193:org.openhab.binding.tcp:1.10.0]
at org.openhab.core.binding.AbstractActiveBinding$BindingActiveService.execute(AbstractActiveBinding.java:157)[194:org.openhab.core.compat1x:2.1.0]
at org.openhab.core.service.AbstractActiveService$RefreshThread.run(AbstractActiveService.java:169)[194:org.openhab.core.compat1x:2.1.0]
did you manage to find a solution to this in the end? I have the same issue with my Owl intuition PV. I can read the udp packet and the string but when I try to extract an element it just returns the whole string whatever I do. works when I cut and paste into an online formatter so I think the syntax is correct.
interestingly, did remove all xpath code references and just left the udp:xxx.xxx.xxx.xxx address and still get the full string returned. out of ideas!
I didn’t get a solution within openHAB in the end. I did get something working with a python script that posted into the influx DB directly. I was going to have another go at this after my updates and a re-install. I am not filled with confidence now based on your experiences.
I did exactly the same as you and had the entire string return no matter what I did.
Glad its not just me then, even though I must add am coming at this from a very low level of programming ability, you could say non existent. As I said, like you nothing I do changes the output. One thing I did notice is that when I intercept the udp packet using wireshark the xml tags in the string look incomplete. I have split it down and I get
I am probably wrong but to my untrained eye (from the examples I have read) it looks like the generating, exporting, generated and exported elements which I am trying to extract are all missing closing > where you would expect to see them. My hunch is that this means the xml is technically not formatted correctly and therefore invalid and this is preventing the xml string being read and transformed correctly by the XPATH commands perhaps.
Not sure if this is any help or not but I have taken a slightly different route. I have written a python script that receives the multicast messages. Using xmltodict it parses them and then I send them to openhab using mqtt. This is probably the long way round.
I have it working for current power, current solar, day power usage, day solar generation, current heating stats and water stats.
The next thing I need to figure out it how to start setting th heating controls.
Hi, I put this down for a while, mainly as I was getting nowhere, but now the nights are getting darker I have got back on it, Still looking for a way of establishing the exporting reading from my Owl so I can hopefully create a rule to identify when I am exporting over a certain amount so it will then turn an electric heater so I put the free electricity to good use. Would be really Interested to understand how you have managed to use MQTT to generate values or if anyone else has managed to get any further with this?