现在的位置: 首页 > 综合 > 正文

C#在客戶端和服務端操作Excel文件

2012年06月09日 ⁄ 综合 ⁄ 共 2543字 ⁄ 字号 评论关闭

一、在客戶端把數據導入到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的設置

刪除以下項目

抱歉!评论已关闭.