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();
    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 + ; 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()[];
    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(, i);
    dataTable.Columns.Add(new DataColumn(cellValueAsRstType.GetText(), typeof(string)));
    }
    for (int j = startRowIndex + ; j <= endRowIndex; j++)
    {
    DataRow dataRow = dataTable.NewRow();
    for (int i = startColumnIndex; i <= endColumnIndex; i++)
    {
    dataRow[i - ] = 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的更多相关文章

  1. C#调用NPOI组件读取excel表格数据转为datatable写入word表格中并向word中插入图片/文字/书签 获得书签列表

    调用word的com组件将400条数据导入word表格中耗时10分钟简直不能忍受,使用NPOI组件耗时4秒钟.但是NPOI中替换书签内容的功能不知道是不支持还是没找到. 辅助类 Excel表格数据与D ...

  2. DataTable数据与Excel表格的相互转换

    using Excel = Microsoft.Office.Interop.Excel; private static Excel.Application m_xlApp = null; /// & ...

  3. C#读取Excel表格中数据并返回datatable

    在软件开发的过程中,经常用到从excel表格中读取数据作为数据源,以下整理了一个有效的读取excel表格的方法. DataTable GetDataTable(string tableName,str ...

  4. 将Excel表格数据转换成Datatable

    /// <summary> /// 将Excel表格数据转换成Datatable /// </summary> /// <param name="fileUrl ...

  5. .NET环境下导出Excel表格的两种方式和导入两种类型的Excel表格

    一.导出Excel表格的两种方式,其中两种方式指的是导出XML数据类型的Excel(即保存的时候可以只需要修改扩展名为.xls)和真正的Excel这两种. using System; using Sy ...

  6. asp.net数据导出到excel表格,并设置表格样式

    1.首先在项目中添加引用

  7. 【c#操作office】--OleDbDataAdapter 与OleDbDataReader方式读取excel,并转换为datatable

    OleDbDataAdapter方式: /// <summary> /// 读取excel的表格放到DataTable中 ---OleDbDataAdapter /// </summ ...

  8. 用NPOI、C#操作Excel表格生成班级成绩单

    在C#中利用NPOI操作Excel表格非常方便,几乎上支持所有的Excel表格本身所有的功能,如字体设置.颜色设置.单元格合并.数值计算.页眉页脚等等. 这里准备使用NPOI生成一个班级成绩单Exce ...

  9. C#程序从Excel表格中读取数据并进行处理

    今天做了一个Excel表格数据处理的事情,因为数据量表较大(接近7000条)所以处理起来有点麻烦,于是写了一个程序, 先将程序记下以便将来查找. using System; using System. ...

随机推荐

  1. linux scull 代码read 方法

    read 的返回值由调用的应用程序解释: 如果这个值等于传递给 read 系统调用的 count 参数, 请求的字节数已经被传送. 这是最好的情况. 如果是正数, 但是小于 count, 只有部分数据 ...

  2. Linux 内核/sbin/hotplug 工具

    如同本章中前面提过的, 无论何时一个设备从系统中增删, 都产生一个"热插拔事件". 这 意味着内核调用用户空间程序 /sbin/hotplug. 这个程序典型地是一个非常小的 ba ...

  3. vue-learning:17- js - methods

    methods 函数是十分优雅的语言特性,它让我们可以采用可复用的方式存储一段逻辑,从而不用重复代码就可以在多处调用.函数.组件.模块等都有复用代码的考虑,函数应该是最早组织复用代码的实现. 在vue ...

  4. nodejs + webpack4 + babel6 结合写Chrome浏览器插件记录(2)

    上来先来看下当前实现的效果吧. 前言 首先感谢第一篇留言鼓励的同学,最近各种繁杂的事,时间占用较多,但是也总抽空继续改造这个项目,期间遇到了各种Vue渲染的问题,常规的字符串渲染会在Chrome插件中 ...

  5. dotnet 通过 WMI 获取指定进程的输入命令行

    本文告诉大家如何使用 WMI 通过 Process 获取这个进程传入的命令行 使用下面代码,使用 Win32_Process 拿到所有的进程,通过 WHERE 判断当前的进程,然后拿到进程传入的命令 ...

  6. Python安装jpype调用java,安装jaydebeapi通过jdbc连接数据库

    pip install JPype1或下载JPype1-0.7.0.tar.gz包 经常出现需要安装VC++服务等 测试代码如下: # Author: zfh import jpype,os,time ...

  7. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站(一)

    在之前已经写了关于Git,Gitlab以及Ansible的两篇博客<Git+Gitlab+Ansible剧本实现一键部署Nginx--技术流ken>,<Git+Gitlab+Ansi ...

  8. Maven工程

    maven:父子工程 1,父工程并没有实质性的内容,所有的jar包都在里面,也就是说只需要管理jar包即可,不参与任务方法逻辑 2,在父工程中拥有很多的子模块,每一个子模块都代表了不用的包如(pack ...

  9. 如何在ClickOnce 应用中使用 GitVersion

    https://github.com/GitTools/GitVersion/issues/1153 I'm using GitVersion in an internal ClickOnce app ...

  10. npm脚本和package.json

    1.什么是npm脚本 在创建node.js项目如一个vue项目,或一个react项目时,项目都会生成一个描述文件package.json . 比如npm允许在package.json文件里面,使用sc ...