DataTable生成Excel文件,返回下载地址

DataTable生成Excel文件,返回下载地址

特点:

1.依据传入参数SheetNum,根据每个Sheet存储的数据行拆分成多个Sheet表

2.根据传入SheetDTAdd,向最后追加一个Sheet表

3.通过ColFunc委托,对列名做修改

4.通过RowFunc委托,对行数据做修改

5.支持.xlsx和.xls

注意:NPOI插件,自行在NuGet上下载

 

 

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Data;
using System.Web;
using NPOI.HSSF.UserModel;
using NPOI.XSSF.UserModel;
using NPOI.SS.UserModel;

public static class ExcelHelper
    {
        #region DataTable生成Excel
        /// <summary>
        /// DataTable生成Excel
        /// </summary>
        /// <param name="SheetDT">需要转换的DataTable</param>
        /// <param name="SheetName">Sheet名称</param>
        /// <param name="ExlName">存储的名字</param>
        /// <param name="ExlPath">存储的地址 相对路径</param>
        /// <param name="SheetNum">每个Sheet中存在的数据量</param>
        /// <param name="sType">Excel版本(0 .xlsx 1 .xls)</param>
        /// <returns>返回生成的路径地址</returns>
        public static string DataTableByExcel(DataTable SheetDT, string SheetName, string ExlName, string ExlPath, int SheetNum = 40000, int sType = 0)
        {
            return DataTableByExcel(SheetDT, SheetName, ExlName, ExlPath, null, "", null, null, SheetNum, sType);
        }
        /// <summary>
        /// DataTable生成Excel
        /// </summary>
        /// <param name="SheetDT">需要转换的DataTable</param>
        /// <param name="SheetName">Sheet名称</param>
        /// <param name="ExlName">存储的名字</param>
        /// <param name="ExlPath">存储的地址 相对路径</param>
        /// <param name="ColFunc">产生Col列的委托,用以重设列名</param>
        /// <param name="RowFunc">产生Row行的委托,用以重设DataRow</param>
        /// <param name="SheetNum">每个Sheet中存在的数据量</param>
        /// <param name="sType">Excel版本(0 .xlsx 1 .xls)</param>
        /// <returns>返回生成的路径地址</returns>
        public static string DataTableByExcel(DataTable SheetDT, string SheetName, string ExlName, string ExlPath, Func<string, string> ColFunc = null, Func<DataRow, DataRow> RowFunc = null, int SheetNum = 40000, int sType = 0)
        {
            return DataTableByExcel(SheetDT, SheetName, ExlName, ExlPath, null, "", ColFunc, RowFunc, SheetNum, sType);
        }

        /// <summary>
        /// DataTable生成Excel
        /// </summary>
        /// <param name="SheetDT">需要转换的DataTable</param>
        /// <param name="SheetName">Sheet名称</param>
        /// <param name="ExlName">存储的名字</param>
        /// <param name="ExlPath">存储的地址 相对路径</param>
        /// <param name="SheetDTAdd">追加的DataTable</param>
        /// <param name="SheetNameAdd">追加的DataTable的Sheet名称</param>
        /// <param name="ColFunc">产生Col列的委托,用以重设列名</param>
        /// <param name="RowFunc">产生Row行的委托,用以重设DataRow</param>
        /// <param name="SheetNum">每个Sheet中存在的数据量</param>
        /// <param name="sType">Excel版本(0 .xlsx 1 .xls)</param>
        /// <returns>返回生成的路径地址</returns>
        public static string DataTableByExcel(
            DataTable SheetDT, string SheetName, string ExlName, string ExlPath,
            DataTable SheetDTAdd, string SheetNameAdd,
            Func<string, string> ColFunc = null, Func<DataRow, DataRow> RowFunc = null,
            int SheetNum = 40000, int sType = 0)
        {
            if (SheetDT == null || SheetDT.Rows.Count <= 0) return "";
            List<string> CloumsList = new List<string>();
            获取列名集合
            foreach (DataColumn column in SheetDT.Columns) CloumsList.Add(column.ColumnName);
            XSSFWorkbook Xbook = new XSSFWorkbook();
            HSSFWorkbook Hbook = new HSSFWorkbook();
            ISheet sheet = null;
            int i = 0;//记录总数据
            int SheetIndex = 1;//Sheet起始索引
            int RowIndex = 0;//每个sheet起始行索引
            int CloumsIndex = 0;//每个sheet起始列索引
            SheetName = string.IsNullOrEmpty(SheetName) ? "sheet" : SheetName;//Sheet名称
            foreach (DataRow dr in SheetDT.Rows)
            {
                i++;
                if ((i - 1) % SheetNum == 0)//每个sheet存储SheetNum条,多出拆分成多个Sheet
                {
                    if (sType == 0) sheet = Xbook.CreateSheet(SheetName + SheetIndex);//添加sheet
                    else Hbook.CreateSheet(SheetName + SheetIndex);//添加sheet
                    CloumsIndex = 0;//重置列索引
                    RowIndex = 0;//重置行索引
                    //遍历列,绑定每个sheet的首行为列名
                    foreach (string Cloums in CloumsList)
                    {
                        string FuncCloums = Cloums;
                        if (ColFunc != null) FuncCloums = ColFunc.Invoke(Cloums);//存在委托
                        if (CloumsIndex == 0) sheet.CreateRow(RowIndex).CreateCell(CloumsIndex).SetCellValue(FuncCloums);
                        else sheet.GetRow(RowIndex).CreateCell(CloumsIndex).SetCellValue(FuncCloums);
                        CloumsIndex++;
                    }
                    SheetIndex++;
                }
                RowIndex++;
                DataRow FuncDR = dr;
                if (RowFunc != null) FuncDR = RowFunc.Invoke(dr);//存在委托
                //根据列索引,绑定数据
                for (int S = 0; S < CloumsList.Count; S++)
                {
                    if (S == 0) sheet.CreateRow(RowIndex).CreateCell(S).SetCellValue(FuncDR[S].ToString());
                    else sheet.GetRow(RowIndex).CreateCell(S).SetCellValue(FuncDR[S].ToString());
                }
            }
            SheetNameAdd = string.IsNullOrEmpty(SheetNameAdd) ? "SheetAdd" : SheetNameAdd;//追加的Sheet名称
            //追加的datatable
            if (SheetDTAdd != null || SheetDTAdd.Rows.Count > 0)
            {
                int j = 0;//记录附加表总数据
                if (sType == 0) sheet = Xbook.CreateSheet(SheetNameAdd);
                else sheet = Hbook.CreateSheet(SheetNameAdd);
                CloumsList.Clear();
                获取列名集合
                foreach (DataColumn column in SheetDTAdd.Columns) CloumsList.Add(column.ColumnName);
                CloumsIndex = 0;//重置列索引
                //遍历列,绑定sheet的首行为列名
                foreach (string Cloums in CloumsList)
                {
                    if (CloumsIndex == 0) sheet.CreateRow(j).CreateCell(CloumsIndex).SetCellValue(Cloums);
                    else sheet.GetRow(j).CreateCell(CloumsIndex).SetCellValue(Cloums);
                    CloumsIndex++;
                }
                foreach (DataRow dr in SheetDTAdd.Rows)
                {
                    j++;
                    //根据列索引,绑定数据
                    for (int S = 0; S < CloumsList.Count; S++)
                    {
                        if (S == 0) sheet.CreateRow(j).CreateCell(S).SetCellValue(dr[S].ToString());
                        else sheet.GetRow(j).CreateCell(S).SetCellValue(dr[S].ToString());
                    }

                }
            }
            //sheet.DisplayGridlines = true;//不显示网格
            if (!Directory.Exists(ExlPath)) Directory.CreateDirectory(ExlPath);
            string strErrorFile = ExlPath + ExlName + ((sType == 0) ? ".xlsx" : ".xls");//相对路径
            string strFilePath = HttpContext.Current.Server.MapPath(strErrorFile);//绝对路径
            //string path = AppDomain.CurrentDomain.BaseDirectory + @"Logs\";
            FileStream file = new System.IO.FileStream(strFilePath, FileMode.Create);
            if (sType == 0)
            {
                Xbook.Write(file);
                Xbook.Close();
                Xbook = null;
            }
            else
            {
                Hbook.Write(file);
                Hbook.Close();
                Hbook = null;
            }
            file.Dispose();
            return strErrorFile;
        }
        #endregion

    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值