【c#操作office】--OleDbDataAdapter 与OleDbDataReader方式读取excel,并转换为datatable
2014-06-17 17:28
756 查看
OleDbDataAdapter方式:
OleDbDataReader 方式:
从上述两个例子不难看出,其实excel也相当于一个数据库,读取excel的sql语句如:string strSql = "Select * From [sheet1$A10:L24]";//读取sheet1工作表A10到L24区域的内容
类似的,读取oracle等数据库,只需把数据库引擎等改为相应的类型就可以了。
/// <summary> /// 读取excel的表格放到DataTable中 ---OleDbDataAdapter /// </summary> /// <param name="strSql"></param> /// <param name="excelpath">excel路径</param> /// <returns>datatable</returns> public static DataTable readexcel(string excelpath,string strSql) { OleDbConnection objConn = null; DataTable dt = new DataTable(); try { string excelConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data source=" + excelpath + ";Excel 8.0;HDR=NO;IMEX=1";//HDR=YES第一行是标题,NO第一行不是标题;IMEX=1表示导入模式,这个模式开启的 Excel 档案只能用来做“写入”用途,还有个重要作用:强制将混合数据转换为文本,可读出excel的数字型的内容。 objConn = new OleDbConnection(excelConn); objConn.Open(); OleDbCommand objCmd = new OleDbCommand(strSql, objConn); OleDbDataAdapter adr = new OleDbDataAdapter(); adr.SelectCommand = objCmd; adr.Fill(dt); objConn.Close(); return dt; } catch (Exception ex) { MessageBox.Show(ex.Message); return null; } }
OleDbDataReader 方式:
/// <summary> /// 读取excel的表格放到DataTable中 ---OleDbDataReader /// </summary> /// <param name="strSql"></param> /// <param name="excelpath">excel路径</param> /// <returns>datatable</returns> public static DataTable readexcel(string excelpath,string strSql) { string excelConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data source=" + excelpath + ";Excel 8.0;HDR=NO;IMEX=1";//HDR=YES第一行是标题,NO第一行不是标题;IMEX=1表示导入模式,这个模式开启的 Excel 档案只能用来做“写入”用途,还有个重要作用:强制将混合数据转换为文本,可读出excel的数字型的内容。 DataTable dt = new DataTable(); try { using (OleDbConnection connection = new OleDbConnection(excelConn)) { OleDbCommand command = new OleDbCommand(strSql, connection); connection.Open(); OleDbDataReader reader; reader = command.ExecuteReader(); dt.Load(reader); //直接把reader转换为datatable reader.Close(); } return dt; } catch (Exception ex) { MessageBox.Show(ex.Message); return null; } }
从上述两个例子不难看出,其实excel也相当于一个数据库,读取excel的sql语句如:string strSql = "Select * From [sheet1$A10:L24]";//读取sheet1工作表A10到L24区域的内容
类似的,读取oracle等数据库,只需把数据库引擎等改为相应的类型就可以了。
相关文章推荐
- 【c#操作office】--OleDbDataAdapter 与OleDbDataReader方式读取excel,并转换为datatable
- OleDbDataAdapter与OleDbDataReader方式读取EXCEL并转换为DataTable
- c#操作excel方式三:使用Microsoft.Office.Interop.Excel.dll读取Excel文件
- c#操作excel方式三:使用Microsoft.Office.Interop.Excel.dll读取Excel文件
- c#操作excel方式三:使用Microsoft.Office.Interop.Excel.dll读取Excel文件
- c#操作excel方式三:使用Microsoft.Office.Interop.Excel.dll读取Excel文件
- c#操作excel方式三:使用Microsoft.Office.Interop.Excel.dll读取Excel文件
- c#操作excel方式三:使用Microsoft.Office.Interop.Excel.dll读取Excel文件
- C#操作EXCEL之用OleDb快速读取数据到DataTable
- C#实现SQL全库检索数据-比较使用DataReader与DataAdapter+Datatable效率,差距惊人!
- c#中采用OLEDB方式来读取EXCEL文件和将数据写入EXCEL文件
- 使用OLEDB方式读取Excel文件到DataTable中数据类型的处理
- C#实现OleDb方式读取excel并在datagridview中显示
- c#中采用OLEDB方式来读取EXCEL文件和将数据写入EXCEL文件
- 源码: C#操作SQL数据库 SQLDataReader/SQLDataAdapter/DataSet/DataTable
- c#中采用OLEDB方式来读取EXCEL文件和将数据写入EXCEL文件
- C#操作EXCEL之用COM对象读取数据到DataTable
- c#操作excel方式二:采用OleDB操作Excel文件
- c#中采用OLEDB方式来读取EXCEL文件和将数据写入EXCEL文件
- c#通过OleDb方式读取Excel的最佳做法,不会丢数据