使用NPOI导入导出Excel(xls/xlsx)数据到DataTable中

using System;
using System.Collections.Generic;
using System.Text;
using System.IO;
using NPOI.SS.UserModel;        //NPOI
using NPOI.HSSF.Util;           //NPOI
using NPOI.HSSF.UserModel;      //NPOI
using NPOI.XSSF.UserModel;      //NPOI
using System.Data.SqlClient;
using System.Data;

 请先下载NPOI的所有dll,然后Add reference.

1.导入

/// <summary>
/// Excel某sheet中内容导入到DataTable中
/// 区分xsl和xslx分别处理
/// </summary>
/// <param name="filePath">Excel文件路径,含文件全名</param>
/// <param name="sheetName">此Excel中sheet名</param>
/// <returns></returns>
public DataTable ExcelSheetImportToDataTable(string filePath, string sheetName)
{
            
    DataTable dt = new DataTable();

    if (Path.GetExtension(filePath).ToLower() == ".xls".ToLower())
    {//.xls
        #region .xls文件处理:HSSFWorkbook
        try
        {
            using (FileStream file = new FileStream(filePath, FileMode.Open, FileAccess.Read))
            {

                hssfworkbook = new HSSFWorkbook(file);
            }
        }
        catch (Exception e)
        {
            throw e;
        }            

        ISheet sheet = hssfworkbook.GetSheet(sheetName);
        System.Collections.IEnumerator rows = sheet.GetRowEnumerator();
        HSSFRow headerRow = (HSSFRow)sheet.GetRow(0);                

        //一行最后一个方格的编号 即总的列数  
        for (int j = 0; j < (sheet.GetRow(0).LastCellNum); j++)
        {
            //SET EVERY COLUMN NAME
            HSSFCell cell = (HSSFCell)headerRow.GetCell(j);

            dt.Columns.Add(cell.ToString());
        }

        while (rows.MoveNext())
        {
            IRow row = (HSSFRow)rows.Current;
            DataRow dr = dt.NewRow();

            if (row.RowNum == 0) continue;//The firt row is title,no need import

            for (int i = 0; i < row.LastCellNum; i++)
            {
                if (i>=dt.Columns.Count)//cell count>column count,then break //每条记录的单元格数量不能大于表格栏位数量 20140213
                {
                    break;
                }

                ICell cell = row.GetCell(i);

                if ((i==0)&&(string.IsNullOrEmpty(cell.ToString())==true))//每行第一个cell为空,break
                {
                    break;
                }

                if (cell == null)
                {
                    dr[i] = null;
                }
                else
                {
                    dr[i] = cell.ToString();
                }
            }
                    
            dt.Rows.Add(dr);
        }
        #endregion
    }
    else
    {//.xlsx
        #region .xlsx文件处理:XSSFWorkbook
        try
        {
            using (FileStream file = new FileStream(filePath, FileMode.Open, FileAccess.Read))
            {

                hssfworkbook = new XSSFWorkbook(file);
            }
        }
        catch (Exception e)
        {
            throw e;
        }            

        ISheet sheet = hssfworkbook.GetSheet(sheetName);
        System.Collections.IEnumerator rows = sheet.GetRowEnumerator();
        XSSFRow headerRow = (XSSFRow)sheet.GetRow(0);

                

        //一行最后一个方格的编号 即总的列数  
        for (int j = 0; j < (sheet.GetRow(0).LastCellNum); j++)
        {
            //SET EVERY COLUMN NAME
            XSSFCell cell = (XSSFCell)headerRow.GetCell(j);

            dt.Columns.Add(cell.ToString());

        }

        while (rows.MoveNext())
        {
            IRow row = (XSSFRow)rows.Current;
            DataRow dr = dt.NewRow();

            if (row.RowNum == 0) continue;//The firt row is title,no need import

            for (int i = 0; i < row.LastCellNum; i++)
            {
                if (i >= dt.Columns.Count)//cell count>column count,then break //每条记录的单元格数量不能大于表格栏位数量 20140213
                {
                    break;
                }

                ICell cell = row.GetCell(i);

                if ((i == 0) && (string.IsNullOrEmpty(cell.ToString()) == true))//每行第一个cell为空,break
                {
                    break;
                }

                if (cell == null)
                {
                    dr[i] = null;
                }
                else
                {
                    dr[i] = cell.ToString();
                }
            }
            dt.Rows.Add(dr);
        }
        #endregion
    }
    return dt;
}

 2.导出

 /// <summary>
        /// NPOI导出Excel,不依赖本地是否装有Excel,导出速度快
        /// </summary>
        /// <param name="dataGridView1">要导出的dataGridView控件</param>
        /// <param name="sheetName">sheet表名</param>
        /// 
        public static void ExportToExcel(DataGridView dataGridView1, string sheetName)
        {
            SaveFileDialog fileDialog = new SaveFileDialog();
            fileDialog.Filter = "Excel(97-2003)|*.xls";
            if (fileDialog.ShowDialog() == System.Windows.Forms.DialogResult.Cancel)
            {
                return;
            }
            //不允许dataGridView显示添加行,负责导出时会报最后一行未实例化错误
            dataGridView1.AllowUserToAddRows = false;
            HSSFWorkbook workbook = new HSSFWorkbook();
            ISheet sheet = workbook.CreateSheet(sheetName);
            IRow rowHead = sheet.CreateRow(0);

            //填写表头
            for (int i = 0; i < dataGridView1.Columns.Count; i++)
            {
                rowHead.CreateCell(i, CellType.String).SetCellValue(dataGridView1.Columns[i].HeaderText.ToString());
            }
            //填写内容
            for (int i = 0; i < dataGridView1.Rows.Count; i++)
            {
                IRow row = sheet.CreateRow(i + 1);
                for (int j = 0; j < dataGridView1.Columns.Count; j++)
                {
                    row.CreateCell(j, CellType.String).SetCellValue(dataGridView1.Rows[i].Cells[j].Value.ToString());
                }
            }

            using (FileStream stream = File.OpenWrite(fileDialog.FileName))
            {
                workbook.Write(stream);
                stream.Close();
            }
            MessageBox.Show("导出数据成功!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
            GC.Collect();
        }

 

转载于:https://www.cnblogs.com/songrun/p/3547738.html

可以使用以下代码将 C# DataTable 数据导入Excel : ```csharp using System.IO; using System.Data; using NPOI.SS.UserModel; using NPOI.XSSF.UserModel; // DataTable 对象 DataTable dataTable = new DataTable(); // Excel 文件路径 string filePath = "D:\\data.xlsx"; // 创建 Excel 工作簿 XSSFWorkbook workbook = new XSSFWorkbook(); // 创建 Excel 工作表 ISheet sheet = workbook.CreateSheet("Sheet1"); // 创建表头行 IRow headerRow = sheet.CreateRow(0); // 设置表头 for (int i = 0; i < dataTable.Columns.Count; i++) { headerRow.CreateCell(i).SetCellValue(dataTable.Columns[i].ColumnName.ToString()); } // 填充数据行 for (int i = 0; i < dataTable.Rows.Count; i++) { IRow dataRow = sheet.CreateRow(i + 1); for (int j = 0; j < dataTable.Columns.Count; j++) { dataRow.CreateCell(j).SetCellValue(dataTable.Rows[i][j].ToString()); } } // 保存 Excel 文件 using (FileStream fs = new FileStream(filePath, FileMode.Create, FileAccess.Write)) { workbook.Write(fs); } ``` 其,`dataTable` 是需要导出DataTable 对象,`filePath` 是导出Excel 文件路径。此外,需要使用 NPOI 库,可以通过 NuGet 包管理器安装。在代码,首先创建了一个空的 Excel 工作簿和工作表,然后创建表头行,设置表头信息。接着,使用循环填充数据行,最后通过 FileStream 将 Excel 文件保存到指定路径。注意,此处使用的是 XSSFWorkbook,可以导出 xlsx 格式的 Excel 文件。如果需要导出 xls 格式的文件,需要使用 HSSFWorkbook。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值