C#把EXCEL数据转换成DataTable

 更新时间:2022年04月09日 16:44:01   作者:農碼一生  
这篇文章介绍了C#把EXCEL数据转换成DataTable的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

C#实现EXCEL表格转DataTable

C#代码实现把Excel文件转化为DataTable,根据Excel的文件后缀名不同,用不同的方法来进行实现,下面通过根据Excel文件的两种后缀名(*.xlsx和*.xls)分别来实现。获取文件后缀名的方法是:Path.GetExtension(fileName)方法,通过引用:using System.IO;实现代码如下:(其中以下代码中出现的filename都是带盘符的绝对路径)

根据Excel文件的后缀名不同调用的主方法

private DataTable FileToDataTable(string fileName)
    {
        DataTable dt = new DataTable();
        string extendName = Path.GetExtension(fileName);//获取文件的后缀名
        switch (extendName.ToLower())
        {
            case ".xls":
                dt = XlsToDataTable(fileName);
                break;
            case ".xlsx":
                dt = XlsxToDataTable(fileName);
                break;
            default:
                break;
        }
        return dt;
    }

XlsToDataTable()

private DataTable XlsToDataTable(string fileName)
    {
        DataTable dataTable = new DataTable();
        Stream stream = null;
        try
        {
            stream = File.OpenRead(fileName);
            HSSFWorkbook hssfworkbook = new HSSFWorkbook(stream);
            HSSFSheet hssfsheet = (HSSFSheet)hssfworkbook.GetSheetAt(hssfworkbook.ActiveSheetIndex);
            HSSFRow hssfrow = (HSSFRow)hssfsheet.GetRow(0);
            int lastCellNum = (int)hssfrow.LastCellNum;
            for (int i = (int)hssfrow.FirstCellNum; i < lastCellNum; i++)
            {
                DataColumn column = new DataColumn(hssfrow.GetCell(i).StringCellValue);
                dataTable.Columns.Add(column);
            }
            dataTable.TableName = hssfsheet.SheetName;
            int lastRowNum = hssfsheet.LastRowNum;
            //列名后,从TABLE第二行开始进行填充数据
            for (int i = hssfsheet.FirstRowNum + 1; i < hssfsheet.LastRowNum; i++)//
            {
                HSSFRow hssfrow2 = (HSSFRow)hssfsheet.GetRow(i);
                DataRow dataRow = dataTable.NewRow();
                for (int j = (int)hssfrow2.FirstCellNum; j < lastCellNum; j++)//
                {
                    dataRow[j] = hssfrow2.GetCell(j);//
                }
                dataTable.Rows.Add(dataRow);
            }
            stream.Close();
        }
        catch (Exception ex)
        {
            ScriptManager.RegisterStartupScript(Page, GetType(), "alertForm", "alert(' Xls to DataTable: " + ex.Message + "');", true);
        }
        finally
        {
            if (stream != null)
            {
                stream.Close();
            }
        }
        return dataTable;
    }

XlsxToDataTable()

public DataTable XlsxToDataTable(string vFilePath)
    {
        DataTable dataTable = new DataTable();
        try
        {
            SLDocument sldocument = new SLDocument(vFilePath);
            dataTable.TableName = sldocument.GetSheetNames()[0];
            SLWorksheetStatistics worksheetStatistics = sldocument.GetWorksheetStatistics();
            int startColumnIndex = worksheetStatistics.StartColumnIndex;
            int endColumnIndex = worksheetStatistics.EndColumnIndex;
            int startRowIndex = worksheetStatistics.StartRowIndex;
            int endRowIndex = worksheetStatistics.EndRowIndex;
            for (int i = startColumnIndex; i <= endColumnIndex; i++)
            {
                SLRstType cellValueAsRstType = sldocument.GetCellValueAsRstType(1, i);
                dataTable.Columns.Add(new DataColumn(cellValueAsRstType.GetText(), typeof(string)));
            }
            for (int j = startRowIndex + 1; j <= endRowIndex; j++)
            {
                DataRow dataRow = dataTable.NewRow();
                for (int i = startColumnIndex; i <= endColumnIndex; i++)
                {
                    dataRow[i - 1] = sldocument.GetCellValueAsString(j, i);
                }
                dataTable.Rows.Add(dataRow);
            }
        }
        catch (Exception ex)
        {
            throw new Exception("Xlsx to DataTable: \n" + ex.Message);
        }
        return dataTable;
    }

到此这篇关于C#把EXCEL数据转换成DataTable的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • c# 成员类型访问权限低于字段本身的实现

    c# 成员类型访问权限低于字段本身的实现

    本文主要介绍了c# 成员类型访问权限低于字段本身的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02
  • C#中如何为枚举类型添加描述方法【小技巧】

    C#中如何为枚举类型添加描述方法【小技巧】

    相信很多人对枚举并不陌生,枚举可以很方便和直观的管理一组特定值。下面这篇文章主要给大家介绍了关于C#中如何为枚举类型添加描述方法的相关资料,需要的朋友可以参考下
    2019-02-02
  • 探秘Unity游戏开发中的状态设计模式

    探秘Unity游戏开发中的状态设计模式

    这篇文章主要介绍了探秘Unity游戏开发中的状态设计模式,状态模式是Unity游戏开发中常用的一种设计模式,可以帮助开发者更好地管理游戏对象状态,提高游戏的可维护性和可扩展性
    2023-05-05
  • C# cefSharep控件的使用详情

    C# cefSharep控件的使用详情

    本文主要介绍了C# cefSharep控件的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • C#检查远程或本地磁盘使用率

    C#检查远程或本地磁盘使用率

    要检查磁盘的使用情况确定程序放哪个服务器和清理垃圾,所以写个小程序帮忙检查。本文给大家介绍C#检查远程或本地磁盘使用率的相关知识,感兴趣的朋友一起学习吧
    2016-04-04
  • C#中获取数据的方法实例

    C#中获取数据的方法实例

    这篇文章主要给大家介绍了关于C#中获取数据的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • C#用Lambda和委托实现模板方法

    C#用Lambda和委托实现模板方法

    C#用Lambda和委托实现模板方法,需要的朋友可以参考一下
    2013-03-03
  • 详解C# 枚举高级用法之Description

    详解C# 枚举高级用法之Description

    这篇文章主要介绍了C# 枚举高级用法之Description,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • C#生成条形码图片的简单方法

    C#生成条形码图片的简单方法

    这篇文章主要介绍了C#生成条形码图片的简单方法,实例分析了了条形码图片的生成原理与实现方法,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-01-01
  • C#实现二叉排序树代码实例

    C#实现二叉排序树代码实例

    今天小编就为大家分享一篇关于C#实现二叉排序树代码实例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-10-10

最新评论