读取Excel文件到DataTable中
private static string[] GetExcelSheetNames(OleDbConnection conn)
{
DataTable dtbSheets = null;
String[] arrExcelSheets = null;
using (conn)
{
try
{
conn.Open();
// Get the data table containing the schema
dtbSheets = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, new object[] { null, null, null, "TABLE" });
if (dtbSheets == null)
{
return null;
}
arrExcelSheets = new String[dtbSheets.Rows.Count];
int intI = 0;
// Add the sheet name to the string array.
foreach (DataRow dr in dtbSheets.Rows)
{
arrExcelSheets[intI] = dr["TABLE_NAME"].ToString();
intI++;
}
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
finally
{
// Close the connection
conn.Close();
}
return arrExcelSheets;
}
}
private static DataTable GetDataTableFromXls(OleDbConnection conn, string spreadSheetName)
{
DataTable datTemp = null;
using (conn)
{
try
{
string strComand = "select * from [" + spreadSheetName + "]";
conn.Open();
OleDbDataAdapter adapter = new OleDbDataAdapter(strComand, conn);
datTemp = new DataTable(spreadSheetName);
adapter.Fill(datTemp);
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
finally
{
// Close the connection
conn.Close();
}
}
return datTemp;
}
// Get the spreadsheet that contain data
public static DataTable GetDataTableWithData(string serverLocation)
{
OleDbConnection xlsConn = null;
DataTable datXls = null;
try
{
string strConnStr = null;
// Connection string for Excel
strConnStr = "Provider=Microsoft.Jet.OLEDB.4.0; Data Source=" + serverLocation + ";Extended Properties=\"Excel 8.0; HDR=NO; IMEX=1\"";
xlsConn = new OleDbConnection(strConnStr);
// Get Sheet names from an Excel Book
string[] arrXls = GetExcelSheetNames(xlsConn);
try
{
foreach (string strSheet in arrXls)
{
xlsConn = new OleDbConnection(strConnStr);
datXls = GetDataTableFromXls(xlsConn, strSheet);
if (datXls != null && datXls.Rows.Count > 0)
{
break;
}
}
}
catch// (SqlException se)
{
//throw new Exception(se.Message);
}
return datXls;
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
finally
{
if (xlsConn.State == ConnectionState.Open)
{
xlsConn.Close();
}
xlsConn.Dispose();
}
}
原文转载:http://www.cnblogs.com/moss_tan_jun/archive/2010/08/06/1793747.html
读取Excel文件到DataTable中的更多相关文章
- 读取excel 文件到datatable
上一篇文章介绍了将datatable 内容导出到excel 文件,这里介绍如何将一个excel 文件读取出来,并保持到datatable 中,实际这样的应用场景也是经常遇到的. 这里继续使用了Micr ...
- C#读取excel数据到datatable中
DataTable dtGBPatient = new DataTable(); string strConn;string excelName; //注意:把一个excel文件看做一个数据库,一个s ...
- 【C#】采用OleDB读取Excel文件转DataTable
using System; using System.Data; using System.Data.OleDb; using System.IO; using System.Linq; using ...
- 读取Excel文件的两种方法
第一种方法:传统方法,采用OleDB读取EXCEL文件, 优点:写法简单,缺点:服务器必须安有此组件才能用,不推荐使用 private DataSet GetConnect_DataSet2(stri ...
- 如何在C#中打开和读取EXCEL文件
这篇文章向您展示如何在C#Windows Forms Application中使用ExcelDataReader,ExcelDataReader.DataSet打开和读取Excel文件.创建一个新的W ...
- 读取Excel文件中的单元格的内容和颜色
怎样读取Excel文件中的单元格的内容和颜色 先创建一个Excel文件,在A1和A2中随意输入内容,设置A1的字体颜色为红色,A2的背景为黄色.需要 using Excel = Microsoft.O ...
- 用python的pandas读取excel文件中的数据
一.读取Excel文件 使用pandas的read_excel()方法,可通过文件路径直接读取.注意到,在一个excel文件中有多个sheet,因此,对excel文件的读取实际上是读取指定文件.并 ...
- C# 读取EXCEL文件的三种经典方法
1.方法一:采用OleDB读取EXCEL文件: 把EXCEL文件当做一个数据源来进行数据的读取操作,实例如下: public DataSet ExcelToDS(string Path) { stri ...
- .Net读取Excel文件时丢失数据的问题 (转载)
相信很多人都试过通过OleDB读取Excel文件,这种方法效率十分高,只是有一点会让人十分头痛,就是当一列中既有混合型数据,又有纯数据时,往往容易丢失数据. 百度过后,改连接字符串 “HDR=YES; ...
随机推荐
- 解决[disabled]="true"与formControlName冲突
import { FormBuilder } from '@angular/forms'; form; constructor(private fb: FormBuilder) { this.form ...
- VMware vCenter 6.5 安装及群集配置介绍
一.介绍 VMware vCenter Server 提供了一个可伸缩.可扩展的平台,为虚拟化管理奠定了基础.可集中管理VMware vSphere环境,与其他管理平台相比,极大地提高了 IT 管理员 ...
- Vue.js 安装
注意:vue.js 不支持 IE8 及其以下版本,学习前请保证你的浏览器兼容 ECMAScript 5,可访问 http://caniuse.com/#feat=es5 查看支持 ECMAScript ...
- 「 HDU P3336 」 Count the string
题目大意 给出一个长度为 $n$ 的字符串 $s$ 要求你求出 $s$ 的每一个前缀在 $s$ 中出现的次数之和.$n\le 200000$. 解题思路 暴力的对每一个前缀进行一次匹配,求出出现次数后 ...
- Luogu P3802 小魔女帕琪
P3802 小魔女帕琪 题目背景 从前有一个聪明的小魔女帕琪,兴趣是狩猎吸血鬼. 帕琪能熟练使用七种属性(金.木.水.火.土.日.月)的魔法,除了能使用这么多种属性魔法外,她还能将两种以上属性组合,从 ...
- mysql5.7报Access denied for xxx@localhost 的解决
使用root用户登录mysql数据库若如下报错 ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using passwor ...
- [UVA11825]Hackers' Crackdown(状压dp)
题解降智警告 吐槽降智警告 思路降智警告 代码降智警告 题目传送门 洛谷 果然水题做多了连半道难点的都能给咱干蒙... 水题做多了降智 --鲁迅 题目大意:见传送门 心路历程见末尾 正解(大概): ...
- IN语句改写EXISTS
-- IN SELECT T1.* FROM role_menu T1 WHERE T1.ROLEUUID IN ( SELECT T2.uuid FROM role T2 WHERE T2.UUID ...
- <Zookeeper>入门 概念
分布式协调服务 Zookeeper 分布式环境的特点 1.分布性 基于一个硬件或者多个硬件设备以及多个软件组成的分布在不同网络计算机上的系统架构,通过消息传递进行通信协调.在空间上部署是可以任意的,网 ...
- 首次开通blog,以后会慢慢把oneNote和印象笔记的笔记转过来
之前一直都是把笔记和经验写到OneNote上面,终于,OneNote无法同步了,转战blog吧,在这上面写一些笔记和一些技术,有空可以慢慢回顾一下.笔记这种东西,过一段时间再看就会有不同的感悟.