我正在尝试使用 axlsx 为 ruby 生成饼图。一切正常,但我似乎无法为每个“饼图”显示数据标签。我要拍摄的或多或少像这张照片。(即它应该有数据标签和引线)。让标签只有数值并像往常一样包含带有颜色映射的图例也很好。
有人知道怎么做吗?
谢谢
我是 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