Asp.NET Core 導出數據到 Excel 文件

来源:https://www.cnblogs.com/rockrose/archive/2023/02/23/17149093.html
-Advertisement-
Play Games

RestSharp RestSharp是一個輕量的,不依賴任何第三方的模擬Http的組件或者類庫。RestSharp具體以下特性;支持net4.0++,支持HTTP的GET, POST, PUT, HEAD, OPTIONS, DELETE等操作,支持oAuth 1, oAuth 2, Basic, ...


在Asp.Net Core開發中,使用NPOI將數據導出到Excel文件中,並返回給前端。

service 層代碼:

        /// <summary>
        /// 將數據導出到excel
        /// </summary>
        /// <param name="projectId"></param>
        /// <param name="ids"></param>
        /// <returns></returns>
        public async Task<IWorkbook> ExportToExcel(Guid projectId, List<Guid> ids = null)
        {
            var entities = await attendanceRecordRepository.Find(x =>
                                                x.ProjectId == projectId)
                                                .ToListAsync();

            if (entities == null || entities.Count == 0) return null;

            //創建工作簿
            IWorkbook workbook = new XSSFWorkbook();
            ISheet sheet = workbook.CreateSheet("考勤記錄");

            //添加表頭
            IRow tableHeader = sheet.CreateRow(0);
            var colNames = new List<string>()
            {
                "姓名", "身份證號", "工號", "人員類型", "辦公室", "工種", "電話號碼", "狀態", "打卡時間"
            };
            for (int i = 0; i < colNames.Count; i++)
            {
                tableHeader.CreateCell(i).SetCellValue(colNames[i]);
                // 自適應寬高
                sheet.AutoSizeColumn(i);
            }

            // 將數據寫入表格中
            if (ids == null || ids.Count == 0)
            {
                // 導出全部
                for (int i = 0; i < entities.Count; i++)
                {
                    // 跳過表頭
                    var row = sheet.CreateRow(i + 1);

                    row.CreateCell(0).SetCellValue(entities[i].Name);
                    row.CreateCell(1).SetCellValue(entities[i].ID_card);
                    row.CreateCell(2).SetCellValue(entities[i].EmployeeNumber);
                    row.CreateCell(3).SetCellValue(entities[i].PersonnelType);
                    row.CreateCell(4).SetCellValue(entities[i].OfficeLocation);
                    row.CreateCell(5).SetCellValue(entities[i].PostName);
                    row.CreateCell(6).SetCellValue(entities[i].PhoneNumber);
                    row.CreateCell(7).SetCellValue(entities[i].Type);
                    row.CreateCell(8).SetCellValue(entities[i].CreateTime.ToString("yyyy-MM-dd HH:mm:ss"));
                }
            }
            else
            {
                // 導出部分
                int rowIndex = 1;
                foreach (var entity in entities)
                {
                    foreach (var id in ids)
                    {
                        if (entity.Id == id)
                        {
                            var row = sheet.CreateRow(rowIndex);

                            row.CreateCell(0).SetCellValue(entity.Name);
                            row.CreateCell(1).SetCellValue(entity.ID_card);
                            row.CreateCell(2).SetCellValue(entity.EmployeeNumber);
                            row.CreateCell(3).SetCellValue(entity.PersonnelType);
                            row.CreateCell(4).SetCellValue(entity.OfficeLocation);
                            row.CreateCell(5).SetCellValue(entity.PostName);
                            row.CreateCell(6).SetCellValue(entity.PhoneNumber);
                            row.CreateCell(7).SetCellValue(entity.Type);
                            row.CreateCell(8).SetCellValue(entity.CreateTime.ToString("yyyy-MM-dd HH:mm:ss"));

                            rowIndex++;
                        }
                    }
                }
            }

            return workbook;
        }

controller 層代碼: 

        /// <summary>
        /// 將數據導出為Excel文件
        /// </summary>
        /// <param name="projectId"></param>
        /// <param name="ids"></param>
        /// <returns></returns>
        [HttpPost("export-to-excel")]
        public async Task<IActionResult> ExportToExcel(Guid projectId, List<Guid> ids = null)
        {
            var workbook = await _attendanceRecordService.ExportToExcel(projectId, ids);

            if(workbook != null)
            {
                var path = Path.Combine(webHostEnvironment.ContentRootPath, "FileName");
                if (!Directory.Exists(path)) //沒有此路徑就新建
                {
                    Directory.CreateDirectory(path);
                }
                var fileFullName = Path.Combine(path, $"{DateTime.Now.ToString("yyyy_MM_dd_HH_mm_ss")}.xlsx");

                // 將表格寫入文件流
                FileStream creatStream = new FileStream(fileFullName, FileMode.Create, FileAccess.Write);
                workbook.Write(creatStream);
                creatStream.Close();

                // 將表格文件轉換成可讀的文件流
                FileStream fileStream = new FileStream(fileFullName, FileMode.Open, FileAccess.Read, FileShare.Read); //讀

                // 將可讀文件流寫入 byte[]
                byte[] bytes = new byte[fileStream.Length];
                fileStream.Read(bytes, 0, bytes.Length);
                fileStream.Close();

                // 把 byte[] 轉換成 Stream (創建其支持存儲區為記憶體的流。)
                MemoryStream stream = new(bytes);

                try
                {
                    return File(stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
                            $"{DateTime.Now.ToString("yyyyMMddHHmmss")}考勤記錄");
                }
                finally
                {
                    System.IO.File.Delete(fileFullName);
                }
                
            }
            return BadRequest();
        }

 


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

-Advertisement-
Play Games
更多相關文章
  • C語言線上運行編譯,是一款可線上編程編輯器,在編輯器上輸入C語言代碼,點擊運行,可線上編譯運行C語言,C語言代碼線上運行調試,C語言線上編譯,可快速線上測試您的C語言代碼,線上編譯C語言代碼發現是否存在錯誤,如果代碼測試通過,將會輸出編譯後的結果。 該線上工具由IT寶庫提供,線上工具後端由眾多Doc ...
  • 不知道各位老色批們平常看視頻都是在哪裡看的,有人說某魚舞蹈區,有人說某牙舞蹈區,要我說都不如西瓜shipin,這裡面個個都是人才,說話又好聽,超喜歡這裡的… 好了話不多說,我們直接開始本次的內容。 模塊安裝 本次需要使用的模塊是requests 模塊,沒安裝的小伙伴直接pip安裝即可。 環境 本次使 ...
  • 現在市面上有很多免費的FTP軟體:如FileZilla ,那如果想自己在代碼中實現與ftp伺服器的上傳下載文件該如何實現那? 本質上ftp協議就是TCP基礎上建立的一種協議,具體如下。 FTP 概述 文件傳輸協議(FTP)作為網路共用文件的傳輸協議,在網路應用軟體中具有廣泛的應用。FTP的目標是提高 ...
  • 一.正常加鎖 當兩個用戶同時註冊一個用戶名時,為保證用戶名不能重覆,因此對其註冊的用戶名加鎖。 具體步驟: 獲得用戶註冊的用戶名,進行判斷,如果為空則對其進行加鎖,保存到資料庫,釋放鎖資源。 二.線程出現阻塞 當A線程加鎖後出現阻塞時,導致數據還沒有存到資料庫,鎖的時間便會失效。 B線程便會執行,對 ...
  • 睏倦的時候寫了個個獲取本地時間,列印總比當前時間大8小時,找了很久原因 package main import ( "fmt" "time" ) func main() { now := time.Now() fmt.Println(now) fmt.Println("nowStr:", now.F ...
  • pandas條件替換值(where&mask) 在日常分析中,經常會遇到對數據的篩選處理相關的工作,我們可以使用loc和iloc定位分析篩選的列或行數據,下麵介紹一種高級篩選的用法where和mask。 pd.where: 替換條件(condition)為Flase處的值 pd.mask: 替換條件 ...
  • 這篇文章主要描述分散式系統中經常討論的CAP理論,它從一致性、可用性和分區容錯性是分散式系統的三個特征,我們只能滿足其中兩個特征,對於分散式系統來說,根據不同的應用場景,可以是AP,也可以是CP。 ...
  • Java ”框架 = 註解 + 反射 + 設計模式“ 之 反射詳解 每博一文案 無論幸福還是苦難,無論光榮還是屈辱,你都要自己遭遇與承受。 —————— 《平凡的世界》 孫少平 多少美好的東西消失和毀滅了,世界還像什麼事也沒有發生,是的,生活在繼續著。 可是,生活中的每一個卻在不斷地失去自己最珍貴的 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...