首页
/
每日頭條
/
職場
/
python讀取excel數據并繪制圖表
python讀取excel數據并繪制圖表
更新时间:2025-02-28 09:58:26
安裝XlsxWriter模塊:

pip install XlsxWriter

python讀取excel數據并繪制圖表(一日一技:Python使用XlsxWriter模塊在Excel工作表中繪制柱形圖)1

pip install XlsxWriter顯示已經安裝好,所以不用重複安裝

代碼1:繪制簡單的柱形圖。

要在Excel工作表上繪制簡單的柱形圖,請使用add_chart()方法和工作簿對象的“ column”關鍵字參數類型。

上代碼:

# import xlsxwriter module import xlsxwriter # Workbook() takes one, non-optional, argument # which is the filename that we want to create. workbook = xlsxwriter.Workbook('chart_column.xlsx') # The workbook object is then used to add new # worksheet via the add_worksheet() method. worksheet = workbook.add_worksheet() # Create a new Format object to formats cells # in worksheets using add_format() method . # here we create bold format object . bold = workbook.add_format({'bold': 1}) # create a data list . headings = ['Number', 'Batch 1', 'Batch 2'] data = [ [2, 3, 4, 5, 6, 7], [80, 80, 100, 60, 50, 100], [60, 50, 60, 20, 10, 20], ] # Write a row of data starting from 'A1' # with bold format . worksheet.write_row('A1', headings, bold) # Write a column of data starting from # 'A2', 'B2', 'C2' respectively . worksheet.write_column('A2', data[0]) worksheet.write_column('B2', data[1]) worksheet.write_column('C2', data[2]) # Create a chart object that can be added # to a worksheet using add_chart() method. # here we create a column chart object . chart1 = workbook.add_chart({'type': 'column'}) # Add a data series to a chart # using add_series method. # Configure the first series. # = Sheet1 !$A$1 is equivalent to ['Sheet1', 0, 0]. # note : spaces is not inserted in b / w # = and Sheet1, Sheet1 and ! # if space is inserted it throws warning. chart1.add_series({ 'name': '= Sheet1 !$B$1', 'categories': '= Sheet1 !$A$2:$A$7', 'values': '= Sheet1 !$B$2:$B$7', }) # Configure a second series. # Note use of alternative syntax to define ranges. # [sheetname, first_row, first_col, last_row, last_col]. chart1.add_series({ 'name': ['Sheet1', 0, 2], 'categories': ['Sheet1', 1, 0, 6, 0], 'values': ['Sheet1', 1, 2, 6, 2], }) # Add a chart title chart1.set_title ({'name': 'Results of data analysis'}) # Add x-axis label chart1.set_x_axis({'name': 'Test number'}) # Add y-axis label chart1.set_y_axis({'name': 'Data length (mm)'}) # Set an Excel chart style. chart1.set_style(11) # add chart to the worksheet # the top-left corner of a chart # is anchored to cell E2 . worksheet.insert_chart('E2', chart1) # Finally, close the Excel file # via the close() method. workbook.close()


輸出為:

python讀取excel數據并繪制圖表(一日一技:Python使用XlsxWriter模塊在Excel工作表中繪制柱形圖)2


代碼2:繪制堆積柱形圖.

要在Excel工作表上繪制堆積柱形圖,請使用add_chart()方法,其類型為工作簿對象的“ column”和子類型“ stacked”關鍵字參數。

上代碼演示:

# import xlsxwriter module import xlsxwriter # Workbook() takes one, non-optional, argument # which is the filename that we want to create. workbook = xlsxwriter.Workbook('chart_column2.xlsx') # The workbook object is then used to add new # worksheet via the add_worksheet() method. worksheet = workbook.add_worksheet() # Create a new Format object to formats cells # in worksheets using add_format() method . # here we create bold format object . bold = workbook.add_format({'bold': 1}) # create a data list . headings = ['Number', 'Batch 1', 'Batch 2'] data = [ [2, 3, 4, 5, 6, 7], [80, 80, 100, 60, 50, 100], [60, 50, 60, 20, 10, 20], ] # Write a row of data starting from 'A1' # with bold format . worksheet.write_row('A1', headings, bold) # Write a column of data starting from # 'A2', 'B2', 'C2' respectively . worksheet.write_column('A2', data[0]) worksheet.write_column('B2', data[1]) worksheet.write_column('C2', data[2]) # Create a chart object that can be added # to a worksheet using add_chart() method. # here we create a stacked Column chart object . chart1 = workbook.add_chart({'type': 'column', 'subtype': 'stacked'}) # Add a data series to a chart # using add_series method. # Configure the first series. # = Sheet1 !$A$1 is equivalent to ['Sheet1', 0, 0]. chart1.add_series({ 'name': '= Sheet1 !$B$1', 'categories': '= Sheet1 !$A$2:$A$7', 'values': '= Sheet1 !$B$2:$B$7', }) # Configure a second series. # Note use of alternative syntax to define ranges. # [sheetname, first_row, first_col, last_row, last_col]. chart1.add_series({ 'name': ['Sheet1', 0, 2], 'categories': ['Sheet1', 1, 0, 6, 0], 'values': ['Sheet1', 1, 2, 6, 2], }) # Add a chart title chart1.set_title ({'name': 'Results of data analysis'}) # Add x-axis label chart1.set_x_axis({'name': 'Test number'}) # Add y-axis label chart1.set_y_axis({'name': 'Data length (mm)'}) # Set an Excel chart style. chart1.set_style(11) # add chart to the worksheet # the top-left corner of a chart # is anchored to cell E2 . worksheet.insert_chart('E2', chart1) # Finally, close the Excel file # via the close() method. workbook.close()

輸出結果:

python讀取excel數據并繪制圖表(一日一技:Python使用XlsxWriter模塊在Excel工作表中繪制柱形圖)3

代碼3:繪制堆積柱形圖百分比.

若要在Excel工作表上繪制“堆積百分比”圖表,請使用add_chart()方法,其類型為工作簿對象的“列”類型和子類型“ percent_stacked”關鍵字參數。

# import xlsxwriter module import xlsxwriter # Workbook() takes one, non-optional, argument # which is the filename that we want to create. workbook = xlsxwriter.Workbook('chart_column3.xlsx') # The workbook object is then used to add new # worksheet via the add_worksheet() method. worksheet = workbook.add_worksheet() # Create a new Format object to formats cells # in worksheets using add_format() method . # here we create bold format object . bold = workbook.add_format({'bold': 1}) # create a data list . headings = ['Number', 'Batch 1', 'Batch 2'] data = [ [2, 3, 4, 5, 6, 7], [80, 80, 100, 60, 50, 100], [60, 50, 60, 20, 10, 20], ] # Write a row of data starting from 'A1' # with bold format . worksheet.write_row('A1', headings, bold) # Write a column of data starting from # 'A2', 'B2', 'C2' respectively . worksheet.write_column('A2', data[0]) worksheet.write_column('B2', data[1]) worksheet.write_column('C2', data[2]) # Create a chart object that can be added # to a worksheet using add_chart() method. # here we create a percent stacked Column chart object . chart1 = workbook.add_chart({'type': 'column', 'subtype': 'percent_stacked'}) # Add a data series to a chart # using add_series method. # Configure the first series. # = Sheet1 !$A$1 is equivalent to ['Sheet1', 0, 0]. chart1.add_series({ 'name': '= Sheet1 !$B$1', 'categories': '= Sheet1 !$A$2:$A$7', 'values': '= Sheet1 !$B$2:$B$7', }) # Configure a second series. # Note use of alternative syntax to define ranges. # [sheetname, first_row, first_col, last_row, last_col]. chart1.add_series({ 'name': ['Sheet1', 0, 2], 'categories': ['Sheet1', 1, 0, 6, 0], 'values': ['Sheet1', 1, 2, 6, 2], }) # Add a chart title chart1.set_title ({'name': 'Results of data analysis'}) # Add x-axis label chart1.set_x_axis({'name': 'Test number'}) # Add y-axis label chart1.set_y_axis({'name': 'Data length (mm)'}) # Set an Excel chart style. chart1.set_style(11) # add chart to the worksheet # the top-left corner of a chart # is anchored to cell E2 . worksheet.insert_chart('E2', chart1) # Finally, close the Excel file # via the close() method. workbook.close()

輸出結果為:

python讀取excel數據并繪制圖表(一日一技:Python使用XlsxWriter模塊在Excel工作表中繪制柱形圖)4

祝學習愉快!

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
神途單職業手遊三端互通
神途單職業手遊三端互通
三端互通神秘宇宙單職業将于8月18日19點公測,集合五大全新系統!​五大特色系統宇宙覺醒系統宇宙覺醒系統可以覺醒三大職業的特殊屬性,一旦覺醒後,可以随意切換三大職業體驗不同屬性,并且附帶不同的職業BUFF,并且帶來各種屬性加成和技能傷害加成...
2025-02-28
十二星座長大做什麼工作射手座
十二星座長大做什麼工作射手座
每個人都有自己獨特的本領和才能,有些是與生俱來的,而有些是通過後天的努力獲得的,我們需要做的就是找到适合自己的方向,發揮最大的潛能,這樣才不會浪費每一份努力。那麼,十二星座都有哪些與生俱來的職業天賦呢?1、白羊座白羊座的人往往具備較強的心理...
2025-02-28
開理發店的真實收入
開理發店的真實收入
理發店随處可見,很多男士除了自己的頭發長了會去理發店之外,大概很多情況下都不理解為什麼女性連洗個頭發都要去理發店花錢。而且通常情況下是花好幾十,是姑娘們太懶了嗎?這估計就是各位男士的誤會了,女性的頭發一般情況下都比較長,自己洗起來非常麻煩,...
2025-02-28
換了工作下一年社保基數怎麼調整
換了工作下一年社保基數怎麼調整
換了工作下一年社保基數怎麼調整?換新工作社保繳費基數怎麼确定?,下面我們就來聊聊關于換了工作下一年社保基數怎麼調整?接下來我們就一起去了解一下吧!換了工作下一年社保基數怎麼調整換新工作社保繳費基數怎麼确定?如果漲工資繳費基數要馬上調整嗎?答...
2025-02-28
林克慶郭永航到黃埔區調研穩增長工作
林克慶郭永航到黃埔區調研穩增長工作
林克慶郭永航到黃埔區調研穩增長工作?廣州日報訊(全媒體記者吳城華通訊員史偉宗)昨日,廣州市委書記林克慶,市委副書記、代市長郭永航到黃埔區捷普電子(廣州)有限公司、華星光電T9項目現場、小鵬汽車智能網聯汽車制造基地調研,随後召開座談會,聽取先...
2025-02-28
Copyright 2023-2025 - www.tftnews.com All Rights Reserved