千家信息网

C#怎么把EXCEL数据转换成DataTable

发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,今天小编给大家分享一下C#怎么把EXCEL数据转换成DataTable的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所
千家信息网最后更新 2025年11月07日C#怎么把EXCEL数据转换成DataTable

今天小编给大家分享一下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# 代码 内容 j++ 很大 大部分 就是 更多 知识点 行业 表格 资讯 资讯频道 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 拼多多提示服务器有问题 数据库设计单表查询题 好玩吧全仿趣步模式软件开发 在服务器中查找数据库安装位置 bogp服务器租用的优势 江西泰来网络技术有限公司 信息收集的内容网络安全 吉林时代网络技术设计 网络安全管理员安全协议 软件开发人员计算机怎么定级 怀柔区正规软件开发规定 语法树怎么画 数据库 网上开盘软件开发商有猫腻 python读数据库中汉字 如何参与政府网络安全 安卓阅读软件开发 金融科技人才缺口 互联网大厂 网络安全信息化办公是干什么 5g网络安全挑战方法 为什么还原数据库出错 网络安全应急处置装置 苏州互联网软件开发要多少钱 数据库转义字符 安全数据库系统课程设计 图片存到异地服务器 济南应用软件开发哪家公司好 服务器bios设置图解教程 网络安全自查及整改情况 mvc 备份数据库 金融科技人才缺口 互联网大厂
0