
답변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]