html5中文学习网

您的位置: 首页 > 网络编程 > ASP.NET » 正文

C#在客端和服端操作Excel文件_.NET教程_编程技术

[ ] 已经帮助:人解决问题
excel

一、在客端把入到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();//束

8r8HTML5中文学习网 - HTML5先行者学习网
8r8HTML5中文学习网 - HTML5先行者学习网
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助