首页
/
每日頭條
/
職場
/
python讀取excel數據并繪制圖表
python讀取excel數據并繪制圖表
更新时间:2025-12-03 06:04:35
安裝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
推荐阅读
下嫁的職場人有哪些
下嫁的職場人有哪些
下嫁的職場人有哪些?退一步清零那些“下嫁”的職場人,接下來我們就來聊聊關于下嫁的職場人有哪些?以下内容大家不妨參考一二希望能幫到您!下嫁的職場人有哪些退一步清零那些“下嫁”的職場人你要學會将目光出離于情緒之外我就是個下嫁的小媳婦“唉,我就像...
2025-12-03
房地産銷售計劃書範文
房地産銷售計劃書範文
一、房地産銷售工作計劃範文精選在已過去的20xx年裡,做為一名房産銷售人員,我所在的銷售部在公司領導的正确帶領下和各部門的積極配合下提前完成了全年的銷售任務,房産銷售員工作計劃。這一年全球的經濟危機蔓延,房地産市場大落大起,整個銷售團隊經曆...
2025-12-03
候鳥遷徙什麼時候最多
候鳥遷徙什麼時候最多
候鳥遷徙什麼時候最多?一隻候鳥的遷徙路(一線調研),今天小編就來說說關于候鳥遷徙什麼時候最多?下面更多詳細答案一起來看看吧!候鳥遷徙什麼時候最多一隻候鳥的遷徙路(一線調研)春光正好,又到了黑頸鶴遷徙的時節。黑頸鶴是世界上唯一生長、繁殖在高原...
2025-12-03
外省公務員如何調回本地
外省公務員如何調回本地
近日,小渝兒收到一些小夥伴的來信,其中有人就提到自己因為在外地上了大學,然後考了外省的公務員,現在想要回到家鄉工作,但又不願辭職,不知道有沒有什麼途徑。這個問題相信很多在外地工作的小夥伴都會遇到,想回家鄉,但不願放棄公務員的工作,十分糾結。...
2025-12-03
态度消極的員工管理
态度消極的員工管理
總是在茶餘飯後,聽到不同的群體私下吐槽老闆:讨厭,煩人,多事,小心眼......感覺不論是什麼樣的企業,似乎那個掌握生殺大權的老闆或直接領導都“挺招人讨厭”。這是一個現象級的存在,或者說是普遍存在的現象,即無論老闆做成什麼樣,員工總會私下吐...
2025-12-03
Copyright 2023-2025 - www.tftnews.com All Rights Reserved