c# Excel转换成DataTable

/// <summary>

/// Excel转换成DataTable(.xls)

/// </summary>

/// <param name="filePath">Excel文件路径</param>

/// <returns></returns>

public static DataTable ExcelToDataTable(string filePath)

{

var dt = new DataTable();

using (var file = new FileStream(filePath, FileMode.Open, FileAccess.Read))

{

var hssfworkbook = new HSSFWorkbook(file);

var sheet = hssfworkbook.GetSheetAt(0);

for (var j = 0; j < 5; j++)

{

dt.Columns.Add(Convert.ToChar(((int)'A') + j).ToString());

}

var rows = sheet.GetRowEnumerator();

while (rows.MoveNext())

{

var row = (HSSFRow)rows.Current;

var dr = dt.NewRow();

for (var i = 0; i < row.LastCellNum; i++)

{

var cell = row.GetCell(i);

if (cell == null)

{

dr[i] = null;

}

else

{

switch (cell.CellType)

{

case CellType.Blank:

dr[i] = "[null]";

break;

case CellType.Boolean:

dr[i] = cell.BooleanCellValue;

break;

case CellType.Numeric:

dr[i] = cell.ToString();

break;

case CellType.String:

dr[i] = cell.StringCellValue;

break;

case CellType.Error:

dr[i] = cell.ErrorCellValue;

break;

case CellType.Formula:

try

{

dr[i] = cell.NumericCellValue;

}

catch

{

dr[i] = cell.StringCellValue;

}

break;

default:

dr[i] = "=" + cell.CellFormula;

break;

}

}

}

dt.Rows.Add(dr);

}

}

return dt;

}

相关推荐
青云交18 分钟前
Java 大视界 -- 基于 Java 的大数据可视化在城市交通拥堵治理与出行效率提升中的应用(398)
java·大数据·flink·大数据可视化·拥堵预测·城市交通治理·实时热力图
一阵没来由的风36 分钟前
拒绝造轮子(C#篇)ZLG CAN卡驱动封装应用
c#·can·封装·zlg·基础封装·轮子
CHEN5_021 小时前
【Java基础面试题】Java基础概念
java·开发语言
二十雨辰1 小时前
[TG开发]照片机器人
java·web3
武昌库里写JAVA2 小时前
JAVA面试汇总(四)JVM(一)
java·vue.js·spring boot·sql·学习
落霞的思绪3 小时前
Java设计模式详细解读
java·开发语言·设计模式
Java小白程序员3 小时前
Spring Framework:Java 开发的基石与 Spring 生态的起点
java·数据库·spring
拂晓银砾3 小时前
Java数据结构-栈
java·数据结构
甄超锋3 小时前
Java Maven更换国内源
java·开发语言·spring boot·spring·spring cloud·tomcat·maven
m0_719084114 小时前
sharding-jdbc读写分离配置
java