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

转载 2007年10月11日 16:09:00

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

JAVA项目学习之坦克大战单机版

本科阶段尽管学过JAVA课程,却始终感觉在云里雾里。这段时间认真学习了马士兵老师JAVA基础教程,跟着写了TankWar的小项目,感觉对JAVA中类的使用有了许多新的认识,思路比原来也清晰多了,在此总...
  • u013456659
  • u013456659
  • 2014年01月12日 21:13
  • 611

go语言的逆袭

Go 语言的哪些特点最吸引您? 并发 Go 最大的特色就是在语言层面天生支持并发,不需要像其他大多数编程语言那样需要开发者自行实现或借助第三方类库实现并...
  • fuyuehua22
  • fuyuehua22
  • 2014年07月21日 14:28
  • 1816

分布式搜索Elasticsearch——创建客户端(五)

org.elasticsearch.client.Client的子类结构如下图所示: org.elasticsearch.client.internal.InternalClient接口在Cli...
  • geloin
  • geloin
  • 2013年01月09日 13:22
  • 5327

FASTDFS 文件同步

文件同步延迟问题的提出     客户端将一个文件上传到一台Storage server后,文件上传工作就结束了。由该Storage server根据binlog中的上传记录将这个文件同步到同组的其他...
  • zhmi_1015
  • zhmi_1015
  • 2017年05月08日 21:19
  • 238

java ftp客戶端

最近打算做一个android上的ftp客户端工具,网上搜索了一下,发现apache commons-net可以很方便的实现,但是这个第三方包中对文件夹的删除与创建(级联)操作并不是特别的方便。删除文件...
  • dliyuedong
  • dliyuedong
  • 2014年04月12日 23:18
  • 3178

关于socket应用:一个不断监听一个进程的服务器以及发送信息的客户端 TCP的三次握手和四次挥手

大端节序:高位节放在低地址        小端节序:高位节放在高地址        PC多采用小端节序,而手机多采用大端节序,在网络传播过程中一律转换成大端节序,所以大端节序也称为网络字节序。    ...
  • hello_bravo_
  • hello_bravo_
  • 2016年07月16日 18:35
  • 1732

rtmp直播协议介绍

1.概述 rtmp协议是adobe公司发明的直播流协议,是目前主流的视频上传协议。 2.术语 AMF(Action Message Format)是在flash和flex中与远程服务端交...
  • yhc223
  • yhc223
  • 2015年02月12日 10:21
  • 1208

GCM 发送接收消息 Message Client Server 服务器端,客户端

最近用了很多时间做GCM,由于碰到很多问题,因此详细做一下记录,以方便各位网友,不用再走我的重复的路.不过我试了一下GCM在国内很不好用.假如开发国外的程序的话,用GCM倒是很不错的选择.国内基本上封...
  • xiaoluoli88
  • xiaoluoli88
  • 2015年10月09日 14:52
  • 539

Oracle客戶端远程导入、导出

1、本机只安裝了Oracle的客戶端的注意,最好把所有的组件都选择安装,这样可以确保本机可以使用imp、exp命令。 2、exp本地导出与imp本地导入 exp命令: 1 exp u...
  • qiukyjava
  • qiukyjava
  • 2013年11月23日 16:29
  • 1032

跨平台的WebRTC客户端框架:OpenWebRTC

Webrtc的ios框架编译 http://www.th7.cn/Program/IOS/201502/390418.shtml OpenWebRTC 是基于 Gstreamer 实现...
  • bamboolsu
  • bamboolsu
  • 2015年10月21日 00:39
  • 5142
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:C#在客戶端和服務端操作Excel文件
举报原因:
原因补充:

(最多只允许输入30个字)