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

linePlusBarChart

class nvd3.linePlusBarChart.linePlusBarChart(**kwargs)

A linePlusBarChart Chart is a type of chart which displays information as a series of data points connected by straight line segments and with some series with rectangular bars with lengths proportional to the values that they represent

../_images/linePlusBarChart.png

Python example:

from nvd3 import linePlusBarChart
chart = linePlusBarChart(name='linePlusBarChart', x_is_date=True, x_axis_format="%d %b %Y")

xdata = [1365026400000000, 1365026500000000, 1365026600000000]
ydata = [-6, 5, -1]
y2data = [36, 55, 11]

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

extra_serie = {"tooltip": {"y_start": "There is ", "y_end": " min"}}
chart.add_serie(name="Serie 2", y=y2data, x=xdata, extra=extra_serie)
chart.buildhtml()

Javascript generated:

data_lineWithFocusChart = [
    {
       "key" : "Serie 1",
       "bar": "true",
       "values" : [
            { "x" : "1365026400000000",
              "y" : -6
            },
            { "x" : "1365026500000000",
              "y" : -5
            },
            { "x" : "1365026600000000",
              "y" : -1
            },
          ],
    },
    {
       "key" : "Serie 2",
       "values" : [
            { "x" : "1365026400000000",
              "y" : 34
            },
            { "x" : "1365026500000000",
              "y" : 56
            },
            { "x" : "1365026600000000",
              "y" : 32
            },
          ],
    }
]

nv.addGraph(function() {
    var chart = nv.models.linePlusBarChart();

    chart.xAxis
        .tickFormat(function(d) { return d3.time.format('%d %b %Y')(new Date(d)) });
    chart.y1Axis
        .tickFormat(d3.format(',f'));
    chart.y2Axis
        .tickFormat(function(d) { return '$' + d3.format(',f')(d) });
    chart.tooltipContent(function(key, y, e, graph) {
        var x = d3.time.format('%d %b %Y %H:%S')(new Date(parseInt(graph.point.x)));
        var y = String(graph.point.y);
        if(key.indexOf('Serie 1') > -1 ){
            var y = '$ ' +  String(graph.point.y) ;
        }
        if(key.indexOf('Serie 2') > -1 ){
            var y =  String(graph.point.y)  + ' min';
        }
        tooltip_str = '<center><b>'+key+'</b></center>' + y + ' on ' + x;
        return tooltip_str;
    });
    d3.select('#linePlusBarChart svg')
        .datum(data_linePlusBarChart)
        .transition().duration(500)
        .attr('height', 350)
        .call(chart);
    return chart;
});