首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >可以使用Python中的Openpyxl将百分比添加到饼图的元素中吗?

可以使用Python中的Openpyxl将百分比添加到饼图的元素中吗?
EN

Stack Overflow用户
提问于 2022-10-31 13:52:06
回答 2查看 51关注 0票数 1

我用Openpyxl创建了excel文件中的饼图。

是否有一种方法可以将百分比添加到饼图中的每个元素,例如,下面的图像?

对于进一步的上下文,excel文件是用Python创建的。我隔离了从代码中创建饼图的代码段:

代码语言:javascript
运行
复制
from openpyxl import Workbook
from openpyxl.chart import PieChart, Reference

imd=30
lid=18.5
cad=10
wad=12
rud=16.5
sad=0
ht=12
othd=40


wb = Workbook()  
sheet = wb.active
sheet.title="Data"

fi,ft=[],[]
sheet['C11'] = imd
sheet['C12'] = lid
sheet['C13'] = cad
sheet['C14'] = wad
sheet['C15'] = rud
sheet['C16'] = sad
sheet['C17'] = ht
sheet['C18'] = othd


sheet2 = wb.create_sheet()
sheet2.title='Charts'

pie=PieChart()

labels = Reference(sheet, min_col=1, min_row=11, max_row=18)
data = Reference(sheet, min_col=3, min_row=10, max_row=18)
pie.add_data(data, titles_from_data=True)
pie.set_categories(labels)
pie.title = "Pie Chart"

sheet2.add_chart(pie, 'A1')

wb.save("temp.xlsx")
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-11-11 10:58:55

是的,您可以使用"DataLabelList“将标签添加到图表中。

解决方案--按照代码添加导入,然后设置对象:

代码语言:javascript
运行
复制
from openpyxl.chart.label import DataLabelList

pie=PieChart()

labels = Reference(sheet, min_col=1, min_row=11, max_row=18)
data = Reference(sheet, min_col=3, min_row=10, max_row=18)
pie.add_data(data, titles_from_data=True)
pie.set_categories(labels)
pie.title = "Pie Chart"

#Set the DataLabelList.
pie.dataLabels = DataLabelList()

#Show the percent on the labels.
pie.dataLabels.showPercent = True

sheet2.add_chart(pie, 'A1')

此外,您还有以下选项:

  • pie.dataLabels.showPercent = True #显示percentage
  • pie.dataLabels.showCatName = True #以显示值name
  • pie.dataLabels.showLeaderLines = True #该选项有一个错误,但它应该显示chart.
  • pie.dataLabels.position = "outEnd“#上每个标签的领导线,以设置标签的位置(选项:'bestFit‘、'b’、'ctr‘、'inBase’、'inEnd','l','outEnd','r','t')
  • pie.dataLabels.separator = "\n“#来设置label.
  • pie.dataLabels.showVal = True #中的分隔符以显示值。

版本: openpyxl~=3.0.10

我希望我帮助过你。

票数 1
EN

Stack Overflow用户

发布于 2022-10-31 15:02:01

首先,您需要遍历所有变量,将数字除以100,从而将数字更改为小数点百分比。然后将单元格号格式更改为百分比。

代码语言:javascript
运行
复制
sheet['C11'] = imd/100  # convert to decimal
sheet['C11'].number_format = '0.0%'  # change to percentage

然后,您需要生成数据标签,并使用方向的第一个字母移动图例位置。

代码语言:javascript
运行
复制
pie.dataLabels = DataLabelList()  # generate data labels
pie.dataLabels.showVal = True  # shows labels
pie.legend.position = 't'  # move legend to top of chart
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/74264322

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档