当前位置: 首页 > 编程日记 > 正文

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();//结束

相关文章:

oracle数据库同步交换的方法

oracle数据同步方案与实现&#xff1a;如何在两个oracle服务器之间交换数据&#xff1f;来源:无忧模板 作者:网络编辑 更新时间:2010-08-09 18:10 点击:次 方案一&#xff1a;建立两个数据库之间的DATA_LINK&#xff0c;直接将新数据写入另一数据库方案二&#xff1a;使用SQL *…

让语音助手听懂方言,这个数据集能搞定

来源 | HyperAI超神经头图 | 来源于网络 侵删方言是语音识别技术发展中必须要迈过去的坎儿&#xff0c;那么如何让模型能够听懂和理解方言呢&#xff1f;使用优质的数据集是一种的方法&#xff0c;本文将介绍一个经典的方言录音数据集 TIMIT。随着科技的成熟&#xff0c;语音识…

Django内置Admin

Django内置的Admin是对于model中对应的数据表进行增删改查提供的组件&#xff0c;使用方式有&#xff1a;依赖APP&#xff1a;django.contrib.authdjango.contrib.contenttypesdjango.contrib.messagesdjango.contrib.sessions模板的context_processors&#xff1a;django.cont…

Puppet扩展篇1-自定义fact结合ENC(hirea)的应用实践

零基础学习Puppet自动化配置管理系列文档在大量节点加入Puppet之后&#xff0c;你至少会面临两个比较大的问题&#xff1a;1、由于节点数的增多&#xff0c;site.pp文件必然会编写更多的节点条目&#xff0c;以及节点包含的类。假设你用Puppet管理500个节点&#xff0c;存在三种…

C#WinForm制作异形窗体/控件

制作异形窗体或控件的思路一般都是想办法生成一个region&#xff0c;然后设置给指定的窗口或控件。生成region的方法有很多&#xff0c;最常用的就是从一幅图片生成&#xff0c;把该图片中的透明色部分“抠”掉&#xff0c;剩下的部分作为一个region。设置窗口或控件的region可…

谷歌提出纯 MLP 构成的视觉架构,无需卷积、注意力 !

来源 | 迈微AI研习社责编 | 寇雪芹头图 | 下载于视觉中国当前&#xff0c;卷积神经网络&#xff08;CNN&#xff09;和基于自注意力的网络&#xff08;如近来大火的 ViT&#xff09;是计算机视觉领域的主流选择&#xff0c;但研究人员没有停止探索视觉网络架构的脚步。近日&…

HttpApplication事件ASP.NET页面周期

学习吧少年........................... 修改中........... 当一次请求到达IIS 1、http.sys将请求发送到指定的应用程序池。 2、应用程序池再将请求交给池中的工作进程&#xff08;w3wp.exe&#xff09;&#xff0c; 3、w3wp.exe根据请求URL的后缀&#xff0c;决定加载那个ISAP…

C#实现对象的Xml格式序列化及反序列化

要序列化的对象的类&#xff1a; [Serializable]public class Person{private string name;public string Name{get{return name;}set{namevalue;}}public string Sex;public int Age31;public Course[] Courses;public Person(){}public Person(string Name){nameName;Sex&qu…

outlook2010 打开总是提示“正在加载配置文件”

公司员工的电脑一打开OUTLOOK2010的时候&#xff0c;总是提示“正在加载配置文件”&#xff0c;要重新启动&#xff0c;还是无法打开,尝试了卸载和重装的方法也没有用.其实,只需下载一个windows search 4.0即可解决.转载于:https://blog.51cto.com/shidilun/1400227

腾讯云存储产品矩阵全面升级,发布三维生态战略

5月10日&#xff0c;腾讯云在北京举行存储产品战略发布会&#xff0c;发布了业界首款十微秒级的极速型云硬盘、业界首款突破百GB 吞吐的文件存储、以及业界首创能够10倍提升数据湖存储分析性能的对象存储三级加速器等新一代云存储产品矩阵。 同时&#xff0c;腾讯云还宣布将围…

围绕云计算 虚拟化技术又呈现新面貌

本文讲的是围绕云计算 虚拟化技术又呈现新面貌&#xff0c;【IT168 资讯】虚拟化技术的三项基本使命-即作为客户端技术&#xff0c;作为服务器技术和作为网络技术&#xff0c;如今正在围绕云计算理念相结合在一起。 起源于X86服务器的虚拟化技术已经快速扩展到存储和网络领域。…

C#字符串处理类

首先介绍一下常用的几个功能&#xff1a; Compare(str1,str2)——比较两个字符串 str1,str2的大小&#xff0c;如果大于返回正数&#xff0c;等于返回0&#xff0c;小于返回负数&#xff01; IndexOf——定位字符串中第一次出现某个给定字符串的位置PadLeft和PadRight——在字…

linux严谨的telnet搭建并用防火墙开通与禁行

今天本打算练练防火墙iptables的东西&#xff0c;本想拿telnet的23号端口练手&#xff0c;没想到在敲实验的时候遇到了些曲折&#xff0c;经过一番努力&#xff0c;把本次实验过程生成文档。实验环境&#xff1a;rhel5.6及系统盘实验目的&#xff1a;通过iptables对telnet服务2…

孩子、老人与海豚,如何用 AI 伴他们走出孤独

“万里归来颜愈少。微笑。笑时犹带岭梅香。试问岭南应不好。却道。此心安处是吾乡。”苏轼的一首《定风波》道出老人心愿&#xff0c;道出人生百态&#xff0c;也道尽世间炎凉。当你走出万里&#xff0c;无论天涯或是海角&#xff0c;每个人的身上都带着自己独有的印记。这份印…

Linux之 手动释放内存

我们在进程中要怎样去描述一个文件呢&#xff1f;我们用目录项(dentry)和索引节点(inode)。它们的定义如下: 所谓"文件", 就是按一定的形式存储在介质上的信息&#xff0c;所以一个文件其实包含了两方面的信息&#xff0c;一是存储的数据本身&#xff0c;二是有关该文…

C#操作Excel导入导出

前些日子&#xff0c;有很多朋友说需要C#导出到Excel的代码&#xff0c;现共享给大家 /// <summary> /// 读取Excel文档 /// </summary> /// <param name"Path">文件名称</param> /// <returns>返回一个数据集</returns> …

中国安全态势越来越好,专访山石网科CSO蒋东毅 | 拟合

从无序中寻找踪迹&#xff0c;从眼前事探索未来。2021 年正值黄金十年新开端&#xff0c;CSDN 以中立技术社区专业、客观的角度&#xff0c;深度探讨中国前沿 IT 技术演进&#xff0c;推出年度重磅企划栏目——「拟合」&#xff0c;通过对话企业技术高管大咖&#xff0c;跟踪报…

《大数据、小数据、无数据:网络世界的数据学术》一 导读

前  言‖ 在“大数据”风靡的当代&#xff0c;学术研究中的“小数据”依旧不容小觑。随着绝对数据量的增加&#xff0c;学者们进行个体研究的能力却不断退化。因为他们从未距离研究对象如此遥远。新工具和新视角成为学术研究的必需品。但相对于“小数据”而言&#xff0c;“大…

UIView旋转角度

2019独角兽企业重金招聘Python工程师标准>>> 最近做一个视图的旋转、放大、拖动、拉伸&#xff0c;其他的都慢慢解决了&#xff0c;就是旋转之后各种问题不好处理&#xff0c;最终归结到旋转角度的不能获取&#xff0c;纠结了好几天&#xff0c;终于找到了获取旋转角…

生成静态文件的新闻系统核心代码

在网上看了许多能生成静态页的新闻系统&#xff0c;但基于asp.net的系统极少&#xff0c;闲下时间来自己写了一个&#xff0c;发出来&#xff0c;大家一起研究&#xff0c;代码没做什么优化&#xff0c;只是实现了功能 using System;using System.Collections;using System.Com…

「软件」2.0时代已经到来,你需要这样的开发工具

互联网催生了软件的繁荣&#xff0c;而在AI浪潮的推动下&#xff0c;软件正在朝着更「智能」的方向发展&#xff0c;也就是「软件2.0」时代。「软件2.0」其实就是神经网络&#xff0c;也就是这一波AI浪潮的基石。 在「软件1.0」时代&#xff0c;程序员用Java、Python、C等语言…

WF4 Beta,RC版文章总结

Visual Studio 2010明天就要发布正式版了&#xff0c;伴随Visual Studio 2010的发布微软的新一代工作流框架Workflow Foundation 4也会正式发布。从Beta版开始就断断续续的开始关注了&#xff0c;并写了一些文章&#xff0c;今天总结下&#xff1a; WF4 Beta1的几篇文章&#x…

亚马逊云科技在中国区域上线机器学习新服务,打造广泛而深入的人工智能与机器学习工具集

2021年5月11日&#xff0c;在完全托管的机器学习服务Amazon SageMaker落地中国区域一周年之际&#xff0c;亚马逊云科技宣布通过与光环新网和西云数据的紧密合作在中国区域进一步落地多项人工智能与机器学习的新服务和功能&#xff0c;丰富了其针对不同企业需求而打造的人工智能…

mysql ERROR 1045

2019独角兽企业重金招聘Python工程师标准>>> C:\Program Files\MySQL\MySQL Server 5.0\bin> mysql -u root -p Enter password: ERROR 1045 (28000): Access denied for user rootlocalhost (using password: YES) 编辑mysql配置文件my.ini&#xff08;不知道在…

C#:将另一个应用程序的主窗口移至屏幕最前

2019独角兽企业重金招聘Python工程师标准>>> 使用WindowsAPI函数SwitchToThisWindow&#xff0c;可以将指定窗口移动到屏幕最前。 如果要将另一个应用程序的窗口移动到最前&#xff0c;只需要找到该窗口的句柄&#xff0c;再调用SwitchToThisWindow函数即可。可通过…

阿里技术文档:Redis+Nginx+Spring全家桶+Dubbo精选

最近花了很长的时间去搜罗整理Java核心技术好文&#xff0c;我把每个Java核心技术的优选文章都整理成了一个又一个的文档。今天就把这些东西分享给老铁们&#xff0c;也能为老铁们省去不少麻烦&#xff0c;想学什么技能了&#xff0c;遇到哪方面的问题了 直接打开文档学一学就好…

网页刷新方法集合

代码如下&#xff1a; <input typebutton value刷新 οnclick"history.go(0)"> 代码如下&#xff1a; <input typebutton value刷新 οnclick"location.reload()"> 代码如下&#xff1a; <input typebutton value刷新 οnclick"…

MOS管体二极管的作用

这里有两种解释&#xff1a; 1、mos管本身自带有寄生二极管&#xff0c;作用是防止VDD过压的情况下&#xff0c;烧坏mos管&#xff0c;因为在过压对MOS管造成破坏之前&#xff0c;二极管先反向击穿&#xff0c;将大电流直接到地&#xff0c;从而避免MOS管被烧坏。 2、防止管子的…

Complex Instance Placement

转自&#xff1a; https://specs.openstack.org/openstack/openstack-user-stories/user-stories/proposed/complex-instance-placement.html This work is licensed under a Creative Commons Attribution 3.0 Unported License.http://creativecommons.org/licenses/by/3.0/…

在SecureCRT下使用sz下载和rz上传文件

之前通过FTP来下载Linux机器上的文件&#xff0c;在Windows编辑完后再上传&#xff0c;如此比较麻烦&#xff0c;刚听同事说用sz和rz命令可以实现在SecureCRT中上传下载。 配置上传下载目录&#xff1a;选择某个session 标签&#xff0c;点鼠标右键&#xff0c;弹出菜单…