通過python xlsxwriter模塊生成EXCEL柱狀圖、餅圖


xlsxwriter模塊不是python自帶的,使用pip下載


import xlsxwriter

#新建一個excel文件,起名為expense01.xlsx
workbook = xlsxwriter.Workbook("expense01.xlsx")
#添加一個Sheet頁,不添寫名字,默認為Sheet1
worksheet = workbook.add_worksheet()
#准備數據
headings=["姓名","數學","語文"]
data=[["板面張",78,60],["糖人李",98,89],["炸糕徐",88,100]]
#樣式
head_style = workbook.add_format({"bold":True,"bg_color":"yellow","align":"center","font":13})
#寫數據
worksheet.write_row("A1",headings,head_style)
for i in range(0,len(data)):
    worksheet.write_row("A{}".format(i+2),data[i])
#添加柱狀圖
chart1 = workbook.add_chart({"type":"column"})
chart1.add_series({
    "name":"=Sheet1!$B$1",#圖例項
    "categories":"=Sheet1!$A$2:$A$4",#X軸 Item名稱
    "values":"=Sheet1!$B$2:$B$4"#X軸Item值
})
chart1.add_series({
    "name":"=Sheet1!$C$1",
    "categories":"=Sheet1!$A$2:$A$4",
    "values":"=Sheet1!$C$2:$C$4"
})
#添加柱狀圖標題
chart1.set_title({"name":"柱狀圖"})
#Y軸名稱
chart1.set_y_axis({"name":"分數"})
#X軸名稱
chart1.set_x_axis({"name":"人名"})
#圖表樣式
chart1.set_style(11)

#添加柱狀圖疊圖子類型
chart2 = workbook.add_chart({"type":"column","subtype":"stacked"})
chart2.add_series({
    "name":"=Sheet1!$B$1",
    "categories":"=Sheet1!$A$2:$a$4",
    "values":"=Sheet1!$B$2:$B$4"
})
chart2.add_series({
    "name":"=Sheet1!$C$1",
    "categories":"=Sheet1!$A$2:$a$4",
    "values":"=Sheet1!$C$2:$C$4"
})
chart2.set_title({"name":"疊圖子類型"})
chart2.set_x_axis({"name":"姓名"})
chart2.set_y_axis({"name":"成績"})
chart2.set_style(12)

#添加餅圖
chart3 = workbook.add_chart({"type":"pie"})
chart3.add_series({
    #"name":"餅形圖",
    "categories":"=Sheet1!$A$2:$A$4",
    "values":"=Sheet1!$B$2:$B$4",
    #定義各餅塊的顏色
     "points":[
         {"fill":{"color":"yellow"}},
         {"fill":{"color":"blue"}},
         {"fill":{"color":"red"}}
    ]
})
chart3.set_title({"name":"餅圖成績單"})
chart3.set_style(3)


#插入圖表
worksheet.insert_chart("B7",chart1)
worksheet.insert_chart("B25",chart2)
worksheet.insert_chart("J2",chart3)

#關閉EXCEL文件
workbook.close()
 
         
         
        

  




效果如圖:

 




免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM