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;

}

相关推荐
七星静香19 分钟前
laravel chunkById 分块查询 使用时的问题
java·前端·laravel
Jacob程序员20 分钟前
java导出word文件(手绘)
java·开发语言·word
ZHOUPUYU20 分钟前
IntelliJ IDEA超详细下载安装教程(附安装包)
java·ide·intellij-idea
q24985969322 分钟前
前端预览word、excel、ppt
前端·word·excel
stewie624 分钟前
在IDEA中使用Git
java·git
Elaine20239139 分钟前
06 网络编程基础
java·网络
G丶AEOM40 分钟前
分布式——BASE理论
java·分布式·八股
落落鱼201341 分钟前
tp接口 入口文件 500 错误原因
java·开发语言
想要打 Acm 的小周同学呀42 分钟前
LRU缓存算法
java·算法·缓存
镰刀出海1 小时前
Recyclerview缓存原理
java·开发语言·缓存·recyclerview·android面试