一、在客 端把 入到Excel文件步
1、 建Excel application 象,打 或生成Excel文件
//服 端 建StringBuilder 象
System.Text.StringBuilder sb=new System .Text .StringBuilder ();
//指定客 端 行 言
sb.Append ("<Script Language=VBScript>");
sb.Append ("<!--/r/n");
sb.Append ("dim xls/r/n");
// 建Excel application 象
sb.Append ("Set xls=CreateObject(/"Excel.Application/")/r/n");
//打 Excel文件
sb.Append ("xls.WorkBooks.Open(C://MyExcel.xls)/r/n");
2、 定工作表,把 入到Excel
// 定欲操作的Excel表
sb.Append ("xls.Sheets(1).Select/r/n");
//获得要操作数据表的行、列数
int rows=dt.Rows.Count,cols=dt.Columns.Count ;
//按行列将数据写入Excel表
for (int j=brow+1;j<brow+cols ;j++)
for (int i=bcol;i<bcol+rows ;i++)
sb.Append ("xls.Sheets(1).Cells(" +(j-1) + "," + (i) + ")=/"" + dt.Rows[i-bcol][j-brow].ToString ().Replace ("/"","'") + "/"/r/n");
3、显示Excel文件
sb.Append ("xls.visible=true/r/n");
4、 放 建的Excel application 象
sb.Append ("set xls=nothing/r/n");
sb.Append ("-->");
sb.Append ("</script>");
5、 代 到客 端
this.Page.RegisterClientScriptBlock("",sb.ToString ());
二、在服 端操作Excel文件
服 端操作Excel文件,是把Excel文件看作 ,把Excel工作表 作 表
1、 建 接 打 接
protected System.Data .OleDb.OleDbConnection dbcnn;
cnnstr="Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=/"Excel 8.0;HDR=Yes;/";Data Source=C://MyExcel.xls”;
dbcnn=new OleDbConnection (cnnstr);
dbcnn.Open ();
2、 建OleDbCommand 象用 操作Excel文件
protected System.Data .OleDb .OleDbCommand dbcmd;
dbcmd=new OleDbCommand();
dbcmd.Connection =dbcnn;
3、操作Excel文件
//获得要操作数据表的行、列数
rows=dt.Rows.Count ;
cols=dt.Columns.Count-1 ;
//按行列将数据写入Excel文件Sheet1工作表
for(int i=0;i<rows;i++)
{
olestr=" insert into [Sheet1$] values(";
for(int j=0;j<cols;j++)
olestr=olestr+"'"+dt.Rows[i][j].ToString ()+"',";
olestr+="'"+Convert.ToDecimal (dt.Rows[i][cols].ToString ())+"')";
dbcmd.CommandText =olestr;
dbcmd.ExecuteNonQuery ();
}
4、 放OleDbCommand 象、 接
dbcmd.Dispose ();
dbcnn.Close ();
5、可操作的SQL 句
//建立名 punchdate的工作表, 指明子段 型。
// 建工作表好 是可指定子段 型,否 都以字符串 出
CREATE TABLE punchdate(mno char(5), punchNum float)
//插入新
Insert into punchdate(mno,punchNum) values(‘09’,9000)
//更新
Update punchdate set punchNum=8000 where mno=’09’
6、不可操作的SQL 句
Delete from punchdate
7、注意 接子串
//HDR=Yes 明工作表第一行 子段名
"Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=/"Excel 8.0;HDR=Yes;/";Data Source=C://MyExcel.xls”
//HDR=No 明工作表 有含子段名的行
"Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=/"Excel 8.0;HDR=No;/";Data Source=C://MyExcel.xls”
8、注意 Web.config的 置