enhance ICapWaterLevel capability
This commit is contained in:
parent
4dad51ddd7
commit
8c7232f737
3 changed files with 42 additions and 42 deletions
|
|
@ -34,17 +34,14 @@ class SachsenLevelBackend(BaseBackend, ICapWaterLevel):
|
|||
DESCRIPTION = u"Level of Sachsen river"
|
||||
BROWSER = SachsenBrowser
|
||||
|
||||
def create_default_browser(self):
|
||||
return self.create_browser()
|
||||
|
||||
def get_list(self):
|
||||
return self.browser.get_rivers_list()
|
||||
|
||||
def get_history(self, id):
|
||||
def iter_gauge_history(self, id):
|
||||
return self.browser.get_history(id)
|
||||
|
||||
def last(self, id):
|
||||
def get_last_measure(self, id):
|
||||
return self.browser.last_seen(id)
|
||||
|
||||
def search(self, pattern):
|
||||
return self.browser.search(pattern)
|
||||
|
||||
def iter_gauges(self, pattern=None):
|
||||
if pattern is None:
|
||||
return self.browser.get_rivers_list()
|
||||
else:
|
||||
return self.browser.search(pattern)
|
||||
|
|
|
|||
|
|
@ -17,17 +17,16 @@
|
|||
# You should have received a copy of the GNU Affero General Public License
|
||||
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
from datetime import datetime, date, time
|
||||
from datetime import datetime, date, time
|
||||
from weboob.tools.browser import BasePage
|
||||
|
||||
from weboob.capabilities.gauge import Gauge, GaugeHistory
|
||||
from weboob.capabilities.gauge import Gauge, GaugeMeasure
|
||||
from weboob.capabilities.base import NotAvailable
|
||||
|
||||
__all__ = ['ListPage', 'HistoryPage']
|
||||
|
||||
class ListPage(BasePage):
|
||||
def get_rivers_list(self):
|
||||
l = []
|
||||
def get_rivers_list(self):
|
||||
for pegel in self.document.getroot().xpath(".//a[@onmouseout='pegelaus()']"):
|
||||
data = pegel.attrib['onmouseover'].strip('pegelein(').strip(')').replace(",'", ",").split("',")
|
||||
gauge = Gauge(int(data[7]))
|
||||
|
|
@ -44,31 +43,28 @@ class ListPage(BasePage):
|
|||
except:
|
||||
gauge.level = NotAvailable
|
||||
try:
|
||||
gauge.flow = float(data[4])
|
||||
gauge.flow = float(data[4])
|
||||
except:
|
||||
gauge.flow = NotAvailable
|
||||
bildforecast = data[5]
|
||||
if bildforecast.__eq__("pf_gerade.png"):
|
||||
if bildforecast.__eq__("pf_gerade.png"):
|
||||
gauge.forecast = "stable"
|
||||
elif bildforecast.__eq__("pf_unten.png"):
|
||||
gauge.forecast = "Go down"
|
||||
else:
|
||||
else:
|
||||
gauge.forecast = NotAvailable
|
||||
|
||||
l.append(gauge)
|
||||
|
||||
return l
|
||||
yield gauge
|
||||
|
||||
class HistoryPage(BasePage):
|
||||
def get_history(self):
|
||||
l = []
|
||||
table = self.document.getroot().cssselect('table[width="215"]')
|
||||
table = self.document.getroot().cssselect('table[width="215"]')
|
||||
first = True
|
||||
for line in table[0].cssselect("tr"):
|
||||
if first:
|
||||
first = False
|
||||
continue
|
||||
history = GaugeHistory()
|
||||
history = GaugeMeasure()
|
||||
leveldate = date(*reversed([int(x) for x in line[0].text_content().split(' ')[0].split(".")]))
|
||||
leveltime = time(*[int(x) for x in line[0].text_content().split(' ')[1].split(":")])
|
||||
history.date = datetime.combine(leveldate, leveltime)
|
||||
|
|
@ -81,9 +77,8 @@ class HistoryPage(BasePage):
|
|||
history.flow = float(line[2].text_content())
|
||||
except:
|
||||
history.flow = NotAvailable
|
||||
l.append(history)
|
||||
|
||||
return l
|
||||
|
||||
yield history
|
||||
|
||||
def first_value(self, table, index):
|
||||
first = NotAvailable
|
||||
|
|
@ -99,8 +94,8 @@ class HistoryPage(BasePage):
|
|||
|
||||
def last_seen(self):
|
||||
tables = self.document.getroot().cssselect('table[width="215"]')
|
||||
gauge = GaugeHistory()
|
||||
gauge = GaugeMeasure()
|
||||
gauge.level = self.first_value(tables, 1)
|
||||
gauge.flow = self.first_value(tables, 2)
|
||||
|
||||
return gauge
|
||||
return gauge
|
||||
|
|
|
|||
|
|
@ -28,13 +28,13 @@ class Gauge(CapBaseObject):
|
|||
CapBaseObject.__init__(self, id)
|
||||
|
||||
self.add_field('name', basestring)
|
||||
self.add_field('river', basestring)
|
||||
self.add_field('river', basestring)
|
||||
self.add_field('level', float)
|
||||
self.add_field('flow', float)
|
||||
self.add_field('lastdate', datetime)
|
||||
self.add_field('forecast', basestring)
|
||||
|
||||
class GaugeHistory(CapBaseObject):
|
||||
class GaugeMeasure(CapBaseObject):
|
||||
def __init__(self):
|
||||
CapBaseObject.__init__(self, None)
|
||||
|
||||
|
|
@ -42,22 +42,30 @@ class GaugeHistory(CapBaseObject):
|
|||
self.add_field('flow', float)
|
||||
self.add_field('date', datetime)
|
||||
|
||||
|
||||
class ICapWaterLevel(IBaseCap):
|
||||
def get_lastlevel(self):
|
||||
def iter_gauge_history(self, id):
|
||||
"""
|
||||
Get history of a gauge.
|
||||
|
||||
@param id [str] ID of the river
|
||||
@return [iter(GaugeMeasure)]
|
||||
"""
|
||||
raise NotImplementedError()
|
||||
|
||||
def get_list(self):
|
||||
def get_last_measure(self, id):
|
||||
"""
|
||||
Get last measure of the gauge.
|
||||
|
||||
@param id [str] ID of the gauge.
|
||||
@return [GaugeMeasure]
|
||||
"""
|
||||
raise NotImplementedError()
|
||||
|
||||
def get_history(self, id):
|
||||
def iter_gauges(self, pattern=None):
|
||||
"""
|
||||
Iter gauges.
|
||||
|
||||
@param pattern [str] if specified, used to search gauges
|
||||
@return [iter(Gauge)]
|
||||
"""
|
||||
raise NotImplementedError()
|
||||
|
||||
def last(self, id):
|
||||
raise NotImplementedError()
|
||||
|
||||
def search(self, pattern):
|
||||
raise NotImplementedError()
|
||||
|
||||
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue