Python-nvd3 is a Python wrapper for NVD3 graph library. NVD3 is an attempt to build re-usable charts and chart components for d3.js without taking away the power that d3.js gives you.

Project location : https://github.com/areski/python-nvd3

lineWithFocusChart

class nvd3.lineWithFocusChart.lineWithFocusChart(**kwargs)

A lineWithFocusChart or line graph is a type of chart which displays information as a series of data points connected by straight line segments. The lineWithFocusChart provide a smaller chart that act as a selector, this is very useful if you want to zoom on a specific time period.

../_images/lineWithFocusChart.png

Python example:

from nvd3 import lineWithFocusChart
chart = lineWithFocusChart(name='lineWithFocusChart', x_is_date=True, x_axis_format="%d %b %Y")
xdata = [1365026400000000, 1365026500000000, 1365026600000000]
ydata = [-6, 5, -1]

extra_serie = {"tooltip": {"y_start": "", "y_end": " ext"},
               "date_format": "%d %b %Y"}
chart.add_serie(name="Serie 1", y=ydata, x=xdata, extra=extra_serie)
chart.buildhtml()

Javascript generated:

data_lineWithFocusChart = [{ "key" : "Serie 1",
   "values" : [
        { "x" : "1365026400000000",
          "y" : -6
        },
        { "x" : "1365026500000000",
          "y" : -5
        },
        { "x" : "1365026600000000",
          "y" : -1
        },
      ],
    "yAxis" : "1"
}]

nv.addGraph(function() {
        var chart = nv.models.lineWithFocusChart();
        chart.yAxis
            .tickFormat(d3.format(',.2f'));
        chart.y2Axis
            .tickFormat(d3.format(',.2f'));
        chart.xAxis
            .tickFormat(function(d) { return d3.time.format('%d %b %y')(new Date(d)) });
        chart.x2Axis
            .tickFormat(function(d) { return d3.time.format('%d %b %y')(new Date(d)) });
        chart.tooltipContent(function(key, y, e, graph) {
            var x = d3.time.format('%d %b %Y')(new Date(parseInt(graph.point.x)));
            var y = String(graph.point.y);
            if(key == 'serie 1'){
                var y = 'There is ' +  String(graph.point.y)  + ' calls';
            }
            tooltip_str = '<center><b>'+key+'</b></center>' + y + ' on ' + x;
            return tooltip_str;
        });
        d3.select('#lineWithFocusChart svg')
            .datum(data_lineWithFocusChart)
            .transition()
            .duration(500)
            .call(chart);
    return chart;
});