C#利用NPOI导出Excel类(简单版)_.NET_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > .NET > C#利用NPOI导出Excel类(简单版)

C#利用NPOI导出Excel类(简单版)

 2014/10/13 15:58:08  秋荷雨翔  程序员俱乐部  我要评论(0)
  • 摘要:代码:usingSystem.Data;usingSystem.IO;usingNPOI.HSSF.UserModel;usingNPOI.SS.UserModel;namespaceahwildlife.Utils{///<summary>///Excel工具类///利用NPOI生成Excel///</summary>publicclassExcelUtil{#region生成Excel///<summary>///生成Excel///<
  • 标签:C# excel 导出excel 利用

代码:

class="code_img_closed" src="/Upload/Images/2014101315/0015B68B3C38AA5B.gif" alt="" />logs_code_hide('0b0481f1-e65b-4f89-9a3f-00a6ed4c115a',event)" src="/Upload/Images/2014101315/2B1B950FA3DF188F.gif" alt="" />
using System.Data;
using System.IO;
using NPOI.HSSF.UserModel;
using NPOI.SS.UserModel;

namespace ahwildlife.Utils
{
    /// <summary>
    /// Excel工具类
    /// 利用NPOI生成Excel
    /// </summary>
    public class ExcelUtil
    {
        #region 生成Excel
        /// <summary>
        /// 生成Excel
        /// </summary>
        public static void CreateExcel(DataTable dt, string path)
        {
            HSSFWorkbook workbook = new HSSFWorkbook();
            ISheet sheet = string.IsNullOrEmpty(dt.TableName) ? workbook.CreateSheet("Sheet1") : workbook.CreateSheet(dt.TableName);//创建工作表

            #region 标题
            IRow row = sheet.CreateRow(0);//在工作表中添加一行
            for (int i = 0; i < dt.Columns.Count; i++)
            {
                ICell cell = row.CreateCell(i);//在行中添加一列
                cell.SetCellValue(dt.Columns[i].ColumnName);//设置列的内容     
            }
            #endregion

            #region 填充数据
            for (int i = 1; i <= dt.Rows.Count; i++)//遍历DataTable行
            {
                DataRow dataRow = dt.Rows[i - 1];
                row = sheet.CreateRow(i);//在工作表中添加一行

                for (int j = 0; j < dt.Columns.Count; j++)//遍历DataTable列
                {
                    ICell cell = row.CreateCell(j);//在行中添加一列
                    cell.SetCellValue(dataRow[j].ToString());//设置列的内容     
                }
            }
            #endregion

            #region 输出到Excel
            MemoryStream ms = new MemoryStream();
            workbook.Write(ms);

            using (FileStream fs = new FileStream(path, FileMode.Create, FileAccess.Write))
            {
                byte[] bArr = ms.ToArray();
                fs.Write(bArr, 0, bArr.Length);
                fs.Flush();
            }
            #endregion

        }
        #endregion

    }
}
View Code

 

发表评论
用户名: 匿名