在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
1. 读取 读取好像有几种方式,通过ADO.net, 通过Microsoft.Interop.Excel支持类库用调用COM读取,还有通过ZIP解压最终读取DOM(这个貌似蛮复杂) 复制代码 代码如下: public DataTable ExcelToDataTable(string strExcelPath, string strSheetName) { string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + strExcelPath + ";" + "Extended Properties=Excel 5.0;"; string strExcel = string.Format("select * from [{0}$]", strSheetName); DataSet ds = new DataSet(); OleDbDataAdapter adapter = new OleDbDataAdapter(strExcel, strConn); adapter.Fill(ds, strSheetName); conn.Close(); return ds.Tables[strSheetName]; } 参数: StrExcelPath Excel文件的路径,strSheetName 要读取表的名称 复制代码 代码如下: Excel.ApplicationClass myExcel = new Excel.ApplicationClass(); //实例一个excel Excel._Workbook xBk; //工作薄 相当于一个Excel文件 Excel._Worksheet xSt; //工作Sheet 一个文件里的表 xBk = myExcel.Workbooks.Add(true); //允许添加 sheet object missing = System.Reflection.Missing.Value;//空值 myExcel.Sheets.Add(missing, missing, 1, Excel.XlSheetType.xlWorksheet);//添加sheet xSt = (Excel._Worksheet)xBk.ActiveSheet;//得到默认sheet xSt.Name = "新的表"; //这里设置表名 xBk.SaveAs( “保存路径” , missing, missing, missing, missing, missing, Excel.XlSaveAsAccessMode.xlShared, missing, missing, missing, missing); //保存文件 myExcel.Quit(); //同样要记得关闭 3.添加内容 复制代码 代码如下: int rowIdx = 2; //从第2行列始 //这里dt 是DataTable数据源 foreach( DataRow dr in dt.Rows ) { int j = 1; //从第1列开始 myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); //用公式的情况,显示A+B+C+D的结果 myExcel.Cells[rowIdx, j++] = string.Format("=SUM(A{0}:D{0})",rowIdx); rowIdx++; } 写完了save一下 xBk.Save(),还是记得要关闭。 |
请发表评论