Plotly.js饼图值格式

时间:2017-04-20 09:51:53

标签: javascript pie-chart plotly

我正在使用Plotly.js创建一些饼图,但我无法弄清楚如何设置值格式。如果我的号码是19.231,那么我得到19.2。我想要19.2310,精度为4位数。我的数据和布局如下:

var data = [{
    values: values,
    labels: labels,
    type: 'pie',
    marker: {
        colors: colors
    },
    textfont: {
        family: 'Helvetica, sans-serif',
        size: 48,
        color: '#000'
    }
}];
var layout = {
    height: 1350,
    width: 1500,
    title: title,
    titlefont: {
        family: 'Helvetica, sans-serif',
        size: 58,
        color: '#000'
    },
    legend: {
        x: 1.1,
        y: 0.5,
        size: 40,
        font: {
            family: 'Helvetica, sans-serif',
            size: 48,
            color: '#000'
        }
    }
};

2 个答案:

答案 0 :(得分:1)

据我所知,您不能直接在Plotly中执行此操作,但可以使用所需的精度添加text值,并将textinfo设置为text



var values = [Math.random(), Math.random(), Math.random()];
var sum = values.reduce(function(pv, cv) { return pv + cv; }, 0);
var digits = 4;
var rounded_values = [];

for (var i = 0; i < values.length; i += 1) {
	rounded_values.push(Math.round(values[i]/sum * 100 * 10**digits) / 10**digits + '%');
}

var myPlot = document.getElementById('myPlot');
var data = [{
    values: values,
    type: 'pie',
    text: rounded_values,
	textinfo: 'text'
}];
Plotly.plot(myPlot, data);
&#13;
<script src="https://cdn.plot.ly/plotly-latest.min.js"></script>
<div id="myPlot"></div>
&#13;
&#13;
&#13;

答案 1 :(得分:1)

我看到文档找到了一些规则

关于高级悬浮模板说

      data: [
        {
          type: "scatter",
          mode: "markers",
          x: x,
          y: y,
          text: t,
          marker: { size: s, sizeref: 4000, sizemode: "area" },
          transforms: [{ type: "groupby", groups: c }],
          hovertemplate:
            "<b>%{text}</b><br><br>" +
            "%{yaxis.title.text}: %{y:$,.0f}<br>" +
            "%{xaxis.title.text}: %{x:.0%}<br>" +
            "Number Employed: %{marker.size:,}" +
            "<extra></extra>"
        }
      ],

您可以在这里将%{y:$ ,. 0f} 0f更改为4f。 像这样

hovertemplate: '%{y:$,.4f}',

Polt.ly JS document