一、在客户端把数据导入到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#在客户端和服务端操作Excel文件相关推荐

  1. C# TCP/IP客户端与服务端数据与文件的传输

    用C#写的 一个简单的TCP通信,主要的功能有: (1) 多个客户端与服务器间的数据交流 (2)可以实现群发的功能 (3)客户端与服务端可以进行文件的传输 主要用到的知识: TCP里的 socket ...

  2. 基于多线程的TCP局域网通信,客户端向服务端上传 文件简单实现源码

    客户端 import java.io.*; import java.net.Socket;/*** ### 作业3:* 完成文件上传案例学习* - 案例需求* 客户端:数据来自于本地文件,接收服务器反 ...

  3. [JAVA]递归实现客户端与服务端之间的文件与文件夹传输

    JAVA实现文件与文件夹传输 声明 其他方法 客户端: 服务端: 声明 本代码的文件夹传输并非完全由本人完成,本人只是在实现递归的基本思想上,稍微处理与改动了原作者的代码的结构,从而实现了文件与文件夹 ...

  4. 【初识Netty使用Netty实现简单的客户端与服务端的通信操作Netty框架中一些重要的类以及方法的解析】

    一.Netty是什么? Netty 由 Trustin Lee(韩国,Line 公司)2004 年开发 本质:网络应用程序框架 实现:异步.事件驱动 特性:高性能.可维护.快速开发 用途:开发服务器和 ...

  5. springboot实现SSE服务端主动向客户端推送数据,java服务端向客户端推送数据,kotlin模拟客户端向服务端推送数据

    SSE服务端推送 服务器向浏览器推送信息,除了 WebSocket,还有一种方法:Server-Sent Events(以下简称 SSE).本文介绍它的用法. 在很多业务场景中,会涉及到服务端向客户端 ...

  6. python中使用socket编程实现带有界面的客户端向服务端发送文件和下载文件

    一主界面: **二:发送文件界面:**首先需要开启发送文件服务端(这里需要注意的是每一次发送文件之前都需要开启一次服务端,因为我在这里将每一次发送文件之后就关闭了客户端和服务端之间的连接) 输出相关客 ...

  7. AIDL 客户端与服务端的双向通信

    时隔一年半了,终于写下了这个续篇,我发现我的很多博客有头无尾,都是有前面一点点,后面就没写去了,也正在想办法都补上 初涉IPC,了解AIDL的工作原理及使用方法 今天聊聊的是客户端和服务端的相互通信, ...

  8. 【Socket网络编程】4.tcp和udp的客户端和服务端收发流程

    tcp和udp的客户端和服务端收发流程 1.udp服务器流程: 1.创建serverSocket 2.设置服务器地址 serverAddr 3.将serverSocket和serverAddr绑定 b ...

  9. twisted:基于python的twisted框架编写一个客户端和服务端的对话聊天空间

    twisted:基于python的twisted框架编写一个客户端和服务端的对话聊天空间 目录 输出结果 实现代码 输出结果 更新-- 实现代码 #基于python的twisted框架编写一个简单的聊 ...

最新文章

  1. 系统调优一之内存子系统
  2. lnmp 切换mysql 版本_LNMP1.5:php多版本切换
  3. 云炬随笔20210819
  4. 项目总结--基于Cortex-A9平台的米兰花智能培育系统
  5. shared_ptr智能指针源码剖析
  6. Datastream 开发打包问题
  7. 读书笔记:《Aspx开发200问》——如果实现动态加载用户空间
  8. php 中 excel表格判断,PHPexcel自动判断excel类型并读取excel所有sheet内容
  9. 使用c++制作微服务计算服务
  10. WordPress添加评论回复的电子邮件警报通知
  11. kitti数据集坐标转换
  12. 如何将 KVM 异构虚拟机启动效率提升 6~10 倍?
  13. SRE 到底是干什么的??
  14. TF卡,Micro SD卡,Micro SDHC卡
  15. 解决Ubuntu下博通网卡驱动问题
  16. 物质模拟器3.0版,变得彩色
  17. 2019最新《Android开发全套学习教程》
  18. 用python Turtle海龟绘制时钟遇到的各种坑汇总
  19. 虚拟机Centos,登陆之后又弹回到登陆界面,无法进入系统
  20. HAL库之SYSTICK时钟频率探究-F407

热门文章

  1. php内置常用函数是哪些,PHP常用函数有哪些
  2. java中将int转换float_在java中将float和double转换为int时有什么区别?
  3. ROS、realsense开发常用命令汇总
  4. Linux那些事儿 之 戏说USB(16)配置
  5. POJ - 3177 Redundant Paths 双联通补边
  6. mysql没有makefile_make: *** 没有指明目标并且找不到 makefile。 停止。 make: ***
  7. java优先级目数_10.Java运算符+(优先级、目数)+
  8. 在ubuntu下设置eclipse开发STM32等嵌入式设备
  9. Udacity机器人软件工程师课程笔记(十九) - 3D感知介绍 - 主动/被动式传感器、RGB-D相机、点云
  10. OpenResty学习中的几个小例子汇总