Как разделить секторы круговой диаграммы, чтобы отобразить дополнительную информацию для каждого сектора в последовательных кольцах?

Как разделить секторы круговой диаграммы, чтобы отобразить дополнительную информацию для каждого сектора в последовательных кольцах?

Я составляю график разбиения диска и доступного пространства.

У меня есть круговая диаграмма, показывающая разбиение: например, 30% /, 70% /home.

Во втором кольце я хочу показать, что 90% /заполнено, 10% /пусто. 10% /homeзаполнено, 90% /homeпусто.

Как мне создать «вторую» серию клиньев?

Приведите пример в LibreOffice, gnuplot, matplotlib и т. д.

Что-то вроде этого:

введите описание изображения здесь

решение1

Предположим, что ваши данные имеют следующий формат:

data = {
    # partition: (frac of disk, frac full)
    "/": (0.3, 0.9),
    "/home": (0.7, 0.1),
}

Попробуйте использовать reportlab.graphicsбиблиотеку (доступную в репозиториях Ubuntu и Fedora как python-reportlab):

from reportlab.graphics.shapes import Drawing
from reportlab.graphics.charts.piecharts import Pie
from reportlab.graphics import renderSVG
from itertools import chain
d = Drawing(400, 400)

outerPie = Pie()
outerPie.x = outerPie.y = 0
outerPie.width = outerPie.height = 400
# 2 slices for each sector (used, unused)
outerPie.data = list(chain(*[
    [fracDisk * fracPart, fracDisk * (1 - fracPart)]
    for (fracDisk, fracPart) in data.values()]))
d.add(outerPie, '')

# Draw smaller pie chart on top of outerPie, leaving outerPie as a ring
innerPie = Pie()
innerPie.x = innerPie.y = 100
innerPie.width = innerPie.height = 200
innerPie.data = [t[0] for t in data.values()]
innerPie.labels = list(data)
d.add(innerPie, '')

renderSVG.drawToFile(d, 'chart.svg')

Пример вывода:

Пример вывода диаграммы

решение2

Это также можно сделать довольно просто в Mathematica (проверено в версии для Linux):

data = {{"/", 0.3, 0.9}, {"/home", 0.7, 0.1}};
PieChart[{
  Labeled[#[[2]], #[[1]]] & /@ data,
  Flatten[{Labeled[#[[2]] *    #[[3]] , "used"], 
           Labeled[#[[2]] * (1-#[[3]]), "free"]} & /@ data]
}, SectorSpacing -> 0]

Или, если вы хотите, чтобы цвета совпадали:

data = {{"/", 0.3, 0.9, Red}, {"/home", 0.7, 0.1, Blue}};
PieChart[{
  Style[Labeled[#[[2]], #[[1]]], #[[4]]] & /@ data,
  Flatten[{Style[Labeled[#[[2]] *    #[[3]] , "used"], #[[4]]], 
           Style[Labeled[#[[2]] * (1-#[[3]]), "free"], Lighter@#[[4]]]} & /@ data]
}, SectorSpacing -> 0]

Круговая диаграмма

Связанный контент