3

我正在尝试使用 axlsx 为 ruby​​ 生成饼图。一切正常,但我似乎无法为每个“饼图”显示数据标签。我要拍摄的或多或少像这张照片。(即它应该有数据标签和引线)。让标签只有数值并像往常一样包含带有颜色映射的图例也很好。

有人知道怎么做吗?

谢谢

4

1 回答 1

8

我是 randym,axlsx 的作者。简短的版本是这尚未实现,因此您将无法根据您的图像将标签添加到图表中。

规范中最大的缺失部分是(ECMA-376 - 第 1 部分)

21.2.2.49 dLbls(数据标签)

需要将其插入系列、图表或两者中,因为它似乎是所有三者的共同元素。

我将在本周晚些时候的某个时间进行更深入的了解,但如果您愿意为 axlsx 做出贡献 - 请在 freenode (#axlsx) 上抓住我或将问题发布到 repo https://github.com/randym/axlsx

更新

事实证明这比我预期的要容易得多。

饼图的 master ( https://github.com/randym/axlsx )现在有一个工作版本。我将在接下来的几天内更新其余受支持的图表类型,并为下周的正式发布进行拍摄。

谢谢你让我知道你需要这个。

这是一个如何使用它的简单示例:

require 'axlsx'
p = Axlsx::Package.new
wb = p.workbook

# Pie Chart
wb.add_worksheet(:name => "Pie Chart") do |sheet|
  sheet.add_row ["First", "Second", "Third", "Fourth"]
  sheet.add_row [1, 2, 3, 4]
  sheet.add_chart(Axlsx::Pie3DChart, :start_at => [0,2], :end_at => [5, 15], :title=> 'dark corner here') do |chart|
    chart.add_series :data => sheet["A2:D2"], :labels => sheet["A1:D1"]
    chart.d_lbls.show_val = true
    chart.d_lbls.show_percent = true
    chart.d_lbls.d_lbl_pos = :outEnd
    chart.d_lbls.show_leader_lines = true
  end
end

p.serialize 'pie_chart_with_data_labels.xlsx'

d_lbls 的可用属性有:

lbl_pos必须是 :bestFit, :b, :ctr, :inBase, :inEnd, :l, :outEnd, :r, :t 之一 默认情况下 axlsx 将使用 :bestFit

以及以下布尔属性:

show_legend_key

show_val

show_cat_name

show_ser_name

显示百分比

show_bubble_size

show_leader_lines

于 2012-07-17T10:51:03.410 回答