C#在客户端和服务端操作Excel文件

晨曦之光 发布于 2012/03/09 14:55
阅读 232
收藏 0
 
一、在客户端把数据导入到 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 的设置
删除以下项目
   <identity impersonate="true" />
   或者这样设置
   <identity impersonate="false" />
三、两种方法的优缺点
   
操作 Excel 文件方法
优点
缺点
客户端
数据导入到 Excel 文件时,很灵活,可将数据填入任意指定的存储格,定位到任意位置
1 、在客户端生成 ActiveX 控件,要将站点设置成可信站点或对 IE 进行安全设置(降低了 IE 的安全性)
2 、对调用的 Excel 模板文件,用户要有权读写
3 、在客户端写 Excel 文件速度比较慢
服务端
1 、对调用的 Excel 模板文件,只要 ASP.NET 有权读写即可
2 、在服务端写 Excel 文件速度比较快
3 、不要对 IE 进行特别设置
对操作的文件只能当作数据库操作,不够灵活
四、流输出
原理:把数据填充到 DataGrid ,然后把 DataGrid 内容放到一个输出流里面,并指定输出流类型为 Excel
System.IO .StringWriter  sw =new System.IO.StringWriter();// 字符串流
System.Web .UI .HtmlTextWriter hw =new System.Web.UI.HtmlTextWriter(sw);//html 流,用字符串流作参数
dg.RenderControl(hw);// DataGrid 流变成字符串流。
Response.ContentType ="application/vnd.ms-excel";// 定义输出流类型为 excel 流。关键语句。
Response.ContentEncoding=System.Text.Encoding.GetEncoding("Big5");// 指定编码类型为大五码
Response.Write(sw.ToString());// 输出流
Response.End();// 结束
 
原文链接:http://blog.csdn.net/21aspnet/article/details/1539674
加载中
返回顶部
顶部