C# 創建EXCEL圖表並保存為圖片

来源:http://www.cnblogs.com/Yesi/archive/2017/12/07/7999434.html
-Advertisement-
Play Games

數據表格能夠清晰的呈現數據信息,但是我們對於一些繁雜多變的數據想要很直觀的看到數據變化走勢或者數據的占比時,數據圖表會更具代表性,並且在呈現數據信息上也更形象,也能獲取更多純數字信息所不能直接展現的信息。在下麵的代碼中,將向您展示如何通過使用免費的Free Spire XLS for .NET組件來 ...


數據表格能夠清晰的呈現數據信息,但是我們對於一些繁雜多變的數據想要很直觀的看到數據變化走勢或者數據的占比時,數據圖表會更具代表性,並且在呈現數據信息上也更形象,也能獲取更多純數字信息所不能直接展現的信息。在下麵的代碼中,將向您展示如何通過使用免費的Free Spire XLS for .NET組件來實現。

原數據表格:

C#

 1 using Spire.Xls;
 2 using System.Drawing;
 3 using System.Drawing.Imaging;
 4 
 5 namespace CreateChart_XLS
 6 {
 7     class Program
 8     {
 9         static void Main(string[] args)
10         {
11             //創建一個Workbook類實例,載入Excel文檔
12             Workbook workbook = new Workbook();
13             workbook.LoadFromFile(@"C:\Users\Administrator\Desktop\Sample.xlsx");
14 
15             //獲取第一個工作表
16             Worksheet sheet = workbook.Worksheets[0];
17 
18             //設置工作表的名稱
19             sheet.Name = "柱狀圖";
20             sheet.GridLinesVisible = false;
21 
22             //創建柱狀圖
23             Chart chart = sheet.Charts.Add(ExcelChartType.ColumnClustered);
24 
25             //指定用於生成圖表的數據區域
26             chart.DataRange = sheet.Range["A2:G6"];
27             chart.SeriesDataFromRange = false;
28 
29             //指定圖表所在的位置
30             chart.LeftColumn = 1;
31             chart.TopRow = 9;
32             chart.RightColumn = 12;
33             chart.BottomRow = 26;
34 
35             //設置圖表的名稱及字體格式
36             chart.ChartTitle = "上半年產品銷售情況(單位:萬美元)";
37             chart.ChartTitleArea.IsBold = true;
38             chart.ChartTitleArea.Size = 12;
39 
40             //設置X軸坐標名稱及字體格式
41             chart.PrimaryCategoryAxis.Title = "產品類別";
42             chart.PrimaryCategoryAxis.Font.IsBold = true;
43             chart.PrimaryCategoryAxis.TitleArea.IsBold = false;
44          
45             //設置Y軸坐標名稱及字體格式
46             chart.PrimaryValueAxis.Title = "銷售額";            
47             chart.PrimaryValueAxis.HasMajorGridLines = false;
48             chart.PrimaryValueAxis.TitleArea.TextRotationAngle = 90;
49             chart.PrimaryValueAxis.MinValue = 0.5;
50             chart.PrimaryValueAxis.TitleArea.IsBold = false;
51 
52             //設置圖例的位置
53             chart.Legend.Position = LegendPositionType.Right;
54 
55              //保存文檔
56             workbook.SaveToFile("ColumnChart.xlsx", ExcelVersion.Version2013);
57 
58 
59              //載入生成圖表後的Excel文檔
60             workbook.LoadFromFile("ColumnChart.xlsx");
61 
62             //遍歷工作簿,診斷是否包含圖表
63             Image[] images = workbook.SaveChartAsImage(sheet);
64 
65              for (int i = 0; i < images.Length; i++)
66               {
67                  //將圖表保存為圖片
68                   images[i].Save(string.Format("img-{0}.png", i), ImageFormat.Png);
69                }
70         }
71     }
72 }

 

生成的圖表文件及圖片如下圖所示:

組件獲取地址:https://www.e-iceblue.cn/Downloads/Free-Spire-XLS-NET.html

以上是對Excel數據表格生成並轉化為圖表的全部操作,希望對你有所幫助,歡迎轉載(轉載請註明出處)

感謝瀏覽!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 下麵這個字元串數組: 實現這個要求的方法也許會很多。下麵Insus.NET使用一個通用的方法來實現:面向對象,創建一個類別Class Digit: class Digit { private int _D; public int D { get { return _D; } set { _D = v ...
  • 通過手機號獲取歸屬地。及控制項LitJosn.dll的簡單使用。 ...
  • 布爾(對應C#的bool)表示是/否兩種狀態,對應關鍵字true、false。對象(對應C#的object)表示任意對象,是所有類型的基類型,關鍵字null表示空對象。Object 在S#中有大量的使用,用的好了熟了會讓你領悟:看山是山;看山不是山;看山還是山。 ...
  • 調試步驟 遠程伺服器: 1.找到本地vs安裝目錄,Enterprise\Common7\IDE目錄下的Remote Debugger整個文件夾複製到遠程伺服器 2.根據伺服器的系統類型,選擇其中的x64或x86文件夾,以管理員身份運行msvsmon.exe 3.將vs生成的項目文件發佈到遠程伺服器, ...
  • 1 //定義一個委托 2 static Func delFunc = (a, b) => 3 { 4 Console.WriteLine("委托線程:" + Thread.CurrentThread.ManagedThreadId); 5 return (a + b).ToString(); 6 }... ...
  • NPOI版本:2.2.1.0 最近公司有這樣的需求: 統計每個部門下麵,多個費用使用情況。部門存在多級,但統計時,只需統計到2級,2級以下的,歸到第2級的部門下。並且要求,第2級部門有個小計,第1級部門需要有個合計。最後,還需提供總計。 本來對NPOI研究的還不夠深入的,以前都是直接通過別人提供的代 ...
  • 很多人一開始學習.net 第一天必定是安裝Visual studio 或者很多關於C#學習的書上第一章節必定是告訴你要你下載一個vs 其實沒有vs未必就不能開發了,只是可能說vs給我的開髮帶來了很多的便捷,但是作為初學者一開始就用它,可能會導致你忽略 了很多原理性的東西 , 一般在windowxp以 ...
  • 1 //==>自建線程 2 new Thread(() => 3 { 4 //線程任務 5 Console.WriteLine(Thread.CurrentThread.ManagedThreadId); 6 }).Start(); 7 8 9 //==>線程池管理線程(不知道線程任務用時,不能控制... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...