|
|
@ -36,36 +36,42 @@ graph.add("graph1",list(zip(x,y))+[None,None]) |
|
|
|
graph.render_in_browser() |
|
|
|
graph.render_in_browser() |
|
|
|
""" |
|
|
|
""" |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
from pygal.adapters import date |
|
|
|
from pygal.util import compute_scale |
|
|
|
from pygal.util import compute_scale |
|
|
|
from pygal.graph.line import Line |
|
|
|
|
|
|
|
from pygal.graph.xy import XY |
|
|
|
from pygal.graph.xy import XY |
|
|
|
import datetime |
|
|
|
import datetime |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class DateY(XY): |
|
|
|
class DateY(XY): |
|
|
|
""" DateY Graph """ |
|
|
|
""" DateY Graph """ |
|
|
|
_offset=datetime.datetime(year=2000,month=1,day=1) |
|
|
|
_offset = datetime.datetime(year=2000, month=1, day=1) |
|
|
|
def _todate(self, d) : |
|
|
|
_adapters = [date] |
|
|
|
""" Converts a number to a date """ |
|
|
|
|
|
|
|
return str(self._offset+datetime.timedelta(seconds=d)) |
|
|
|
def _todate(self, d): |
|
|
|
def _tonumber(self,d) : |
|
|
|
""" Converts a number to a date """ |
|
|
|
|
|
|
|
return str(self._offset + datetime.timedelta(seconds=d)) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def _tonumber(self, d): |
|
|
|
""" Converts a date to a number """ |
|
|
|
""" Converts a date to a number """ |
|
|
|
if d==None: return None |
|
|
|
if d is None: |
|
|
|
return (d-self._offset).total_seconds() |
|
|
|
return None |
|
|
|
|
|
|
|
return (d - self._offset).total_seconds() |
|
|
|
|
|
|
|
|
|
|
|
def _get_value(self, values, i): |
|
|
|
def _get_value(self, values, i): |
|
|
|
return 'x=%s, y=%s' % (self._todate(values[i][0]),self._format(values[i][1])) |
|
|
|
return 'x=%s, y=%s' % ( |
|
|
|
|
|
|
|
self._todate(values[i][0]), self._format(values[i][1])) |
|
|
|
|
|
|
|
|
|
|
|
def _compute(self): |
|
|
|
def _compute(self): |
|
|
|
# Approximatively the same code as in XY. |
|
|
|
# Approximatively the same code as in XY. |
|
|
|
# The only difference is the transformation of dates to numbers |
|
|
|
# The only difference is the transformation of dates to numbers |
|
|
|
# (beginning) and the reversed transforamtion to dates (end) |
|
|
|
# (beginning) and the reversed transformation to dates (end) |
|
|
|
self._offset = min([val[0] |
|
|
|
self._offset = min([val[0] |
|
|
|
for serie in self.series |
|
|
|
for serie in self.series |
|
|
|
for val in serie.values |
|
|
|
for val in serie.values |
|
|
|
if val[0] is not None]) |
|
|
|
if val[0] is not None] |
|
|
|
for serie in self.series : |
|
|
|
or [datetime.datetime.fromtimestamp(0)]) |
|
|
|
serie.values=[(self._tonumber(v[0]),v[1]) for v in serie.values] |
|
|
|
for serie in self.series: |
|
|
|
|
|
|
|
serie.values = [(self._tonumber(v[0]), v[1]) for v in serie.values] |
|
|
|
|
|
|
|
|
|
|
|
xvals = [val[0] |
|
|
|
xvals = [val[0] |
|
|
|
for serie in self.series |
|
|
|
for serie in self.series |
|
|
@ -86,7 +92,8 @@ class DateY(XY): |
|
|
|
serie.points = serie.values |
|
|
|
serie.points = serie.values |
|
|
|
if self.interpolate and rng: |
|
|
|
if self.interpolate and rng: |
|
|
|
vals = list(zip(*sorted( |
|
|
|
vals = list(zip(*sorted( |
|
|
|
[t for t in serie.points if None not in t], key=lambda x: x[0]))) |
|
|
|
[t for t in serie.points if None not in t], |
|
|
|
|
|
|
|
key=lambda x: x[0]))) |
|
|
|
serie.interpolated = self._interpolate( |
|
|
|
serie.interpolated = self._interpolate( |
|
|
|
vals[1], vals[0], xy=True, xy_xmin=xmin, xy_rng=rng) |
|
|
|
vals[1], vals[0], xy=True, xy_xmin=xmin, xy_rng=rng) |
|
|
|
|
|
|
|
|
|
|
|