`

C#在客户端和服务端操作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();//结束
 
分享到:
评论

相关推荐

    c# winfrom+wcf实现的文件服务器

    支持在线编辑所有文件(Word,excel,powerpoint,txt,rar等),文件上传,移动,删除等 可以实现文件集中管理,为指定用户提供如:查看,编辑,再授权,删除等操作 支持文件操作备份,防止意外删除文件 支持文件编辑日志,可查看...

    《Visual C# .NET精彩编程实例集锦》配套光盘文件【全】

    《Visual C# .NET精彩编程实例集锦》配套光盘文件【全】 目录回到顶部↑ 前言 第1章 控件操作 实例1 如何使用错误提醒控件 实例2 如何使用信息提示控件 实例3 如何使用菜单控件 实例4 如何使用工具栏控件 实例...

    Visual C# .NET精彩编程实例集锦

    实例30 如何操作Excel文件 实例31 如何播放MP3文件 实例32 如何播放VCD文件 实例33 如何播放DVD文件 实例34 如何播放Flash文件 实例35 如何播放RealPlayer文件 第3章 程序设置 ---------------------------------- ...

    Socket局域网里可以互相发送信息

    服务端和客户端 首次加载由客户端请求服务端,连接通以后可以互相发送信息进行聊天,只限于局域网发送。

    Unity3D游戏毕业设计基于Socket构建异步网络通信服务战斗系统暗黑战神C#源码

    服务端部分:(使用C#开发) 实现一个轻量级的服务器逻辑框架:包含服务层,业务层,缓存层,数据层。 基于Socketi构建支持高并发的异步网络通信服务 可扩展的网络通讯协议设计 Mysql3数据库的操作与管理 客户端...

    vc++ 应用源码包_1

    Excel文件的导入和导出操作 主要的实现在CMyExcel类中。 expclass_src dll库的演示。 fge.1.1.alpha.sdk 精灵系统,一套MFC渲染引擎,含2D/3D等渲染,效果看源码,IFEngine是整个引擎接口,IFSystem是硬件查询系统,...

    vc++ 应用源码包_2

    Excel文件的导入和导出操作 主要的实现在CMyExcel类中。 expclass_src dll库的演示。 fge.1.1.alpha.sdk 精灵系统,一套MFC渲染引擎,含2D/3D等渲染,效果看源码,IFEngine是整个引擎接口,IFSystem是硬件查询系统,...

    vc++ 应用源码包_6

    Excel文件的导入和导出操作 主要的实现在CMyExcel类中。 expclass_src dll库的演示。 fge.1.1.alpha.sdk 精灵系统,一套MFC渲染引擎,含2D/3D等渲染,效果看源码,IFEngine是整个引擎接口,IFSystem是硬件查询系统,...

    vc++ 应用源码包_5

    Excel文件的导入和导出操作 主要的实现在CMyExcel类中。 expclass_src dll库的演示。 fge.1.1.alpha.sdk 精灵系统,一套MFC渲染引擎,含2D/3D等渲染,效果看源码,IFEngine是整个引擎接口,IFSystem是硬件查询系统,...

    vc++ 应用源码包_3

    Excel文件的导入和导出操作 主要的实现在CMyExcel类中。 expclass_src dll库的演示。 fge.1.1.alpha.sdk 精灵系统,一套MFC渲染引擎,含2D/3D等渲染,效果看源码,IFEngine是整个引擎接口,IFSystem是硬件查询系统,...

    vc++ 开发实例源码包

    Excel文件的导入和导出操作 如题。主要的实现在CMyExcel类中。 expclass_src dll库的演示。 fge.1.1.alpha.sdk 精灵系统,一套MFC渲染引擎,含2D/3D等渲染,效果看源码,IFEngine是整个引擎接口,IFSystem是硬件...

    asp.net知识库

    如何在客户端调用服务端代码 页面一postback,它就显示页面的最顶端,怎样让它定位在某一位置? 如何保证页面刷新后的滚动条位置 清除网页历史记录,屏蔽后退按钮! 如何传值在2个页面之间 :要求不刷新父页面,并且...

    简单的winform开发架子

    3,部署的话,看demo目录(更新服务端是要架设IIS的,并且将更新文件放入根目录下,客户端的自动更新程序才能成功更新)。 4,最后说下,写的质量比较低,看看就可以了,呵呵。我会继续更新的,感谢网络上提供的代码,我...

    NFine快速开发框架源码 NFineRapidFramework.rar

    NFine快速开发框架源码 源码描述: 一、源码特点 1、NFine 是基于 C# 语言的极速 WEB + ORM 框架,其核心设计目标是开发迅速、代码量少、学习简单、功能强大、轻量级、易扩展,让Web... 2、数据库文件在DB文件夹中

    短信彩信群发系统平台源码1.0版

    彩翼通WEB短信平台基于C#3.5 + MSSQL2005 R2平台开发,前端采用jQuery1.4.1 + DIV +CSS展示,系统CS源码采用3层架构(数据层+逻辑层+表现层),系统采用存储过程的设计,方便改动及二次开发。 1、【彩翼通短信平台...

    Grid++Report5.6报表开发工具

    B/S报表只要在WEB服务器布署报表网页与报表插件安装包,服务端不需其它配置,客户端零配置。 14、易学易用:完全可视化设计,完善的复制/剪切/粘贴(Copy/Cut/Paste)和恢复重做(Undo/Redo)功能,专业的拖放操作与即时...

    Grid++Report5.5报表工具

    B/S报表只要在WEB服务器布署报表网页与报表插件安装包,服务端不需其它配置,客户端零配置。 14、易学易用:完全可视化设计,完善的复制/剪切/粘贴(Copy/Cut/Paste)和恢复重做(Undo/Redo)功能,专业的拖放操作与即时...

    锐浪报表Grid++Report5.3

    B/S报表只要在WEB服务器布署报表网页与报表插件安装包,服务端不需其它配置,客户端零配置。 14、易学易用:完全可视化设计,完善的复制/剪切/粘贴(Copy/Cut/Paste)和恢复重做(Undo/Redo)功能,专业的拖放操作与即时...

    Grid++Report5报表工具 版本5.5.0.8

    B/S报表只要在WEB服务器布署报表网页与报表插件安装包,服务端不需其它配置,客户端零配置。 14、易学易用:完全可视化设计,完善的复制/剪切/粘贴(Copy/Cut/Paste)和恢复重做(Undo/Redo)功能,专业的拖放操作与即时...

Global site tag (gtag.js) - Google Analytics