从DataTable导出Excel,并下载,删除Excel进程。

页面上加入一个button即可.
源代码如下:

None.gifusing System;
None.gif
using System.Collections;
None.gif
using System.ComponentModel;
None.gif
using System.Data;
None.gif
using System.Drawing;
None.gif
using System.Web;
None.gif
using System.Web.SessionState;
None.gif
using System.Web.UI;
None.gif
using System.Web.UI.WebControls;
None.gif
using System.Web.UI.HtmlControls;
None.gif
using Microsoft.Office.Interop.Excel;
None.gif
None.gif
namespace Test
ExpandedBlockStart.gifContractedBlock.gif
dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif    
/**//// <summary>
InBlock.gif    
/// TestExcel 的摘要说明。
ExpandedSubBlockEnd.gif    
/// </summary>

InBlock.gif    public class TestExcel : System.Web.UI.Page
ExpandedSubBlockStart.gifContractedSubBlock.gif    
dot.gif{
InBlock.gif        
protected System.Web.UI.WebControls.Button Button1;
InBlock.gif    
InBlock.gif        
private void Page_Load(object sender, System.EventArgs e)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            
ExpandedSubBlockEnd.gif        }

InBlock.gif
ExpandedSubBlockStart.gifContractedSubBlock.gif        
Web 窗体设计器生成的代码#region Web 窗体设计器生成的代码
InBlock.gif        
override protected void OnInit(EventArgs e)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            
//
InBlock.gif            
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
InBlock.gif            
//
InBlock.gif
            InitializeComponent();
InBlock.gif            
base.OnInit(e);
ExpandedSubBlockEnd.gif        }

InBlock.gif        
ExpandedSubBlockStart.gifContractedSubBlock.gif        
/**//// <summary>
InBlock.gif        
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
InBlock.gif        
/// 此方法的内容。
ExpandedSubBlockEnd.gif        
/// </summary>

InBlock.gif        private void InitializeComponent()
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{    
InBlock.gif            
this.Button1.Click += new System.EventHandler(this.Button1_Click);
InBlock.gif            
this.Load += new System.EventHandler(this.Page_Load);
InBlock.gif
ExpandedSubBlockEnd.gif        }

ExpandedSubBlockEnd.gif        
#endregion

InBlock.gif
InBlock.gif        
private void Button1_Click(object sender, System.EventArgs e)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            
try
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
string DownloadPath=Server.MapPath(".");    //副本的文件夹路径。
InBlock.gif                
//副本的文件名。
InBlock.gif
                string TempFileName = DateTime.Now.ToString("yyyyMMdd"+ DateTime.Now.Hour + DateTime.Now.Minute + DateTime.Now.Second + ".XLS"
InBlock.gif                
this.txtTempFileName.Text=TempFileName;
InBlock.gif                
object missing = System.Reflection.Missing.Value;
InBlock.gif                
object missing2 = System.Reflection.Missing.Value;
InBlock.gif                ApplicationClass myExcel
=new ApplicationClass();
InBlock.gif
InBlock.gif                Workbook myBook
=(Workbook)myExcel.Workbooks.Add(missing);
InBlock.gif                Worksheet curSheet 
= (Worksheet)myBook.Sheets[1];
InBlock.gif                
//设置Excel样式
InBlock.gif
                Range r1=(Range)myExcel.Cells[1,2];
InBlock.gif
InBlock.gif                Range r2
=(Range)myExcel.Cells[3,4];
InBlock.gif
InBlock.gif                r1.Font.Bold
=true;
InBlock.gif                r2.Font.Bold
=true;
InBlock.gif
InBlock.gif
InBlock.gif                
string DownloadFilePath=DownloadPath+"\\"+TempFileName;
InBlock.gif
InBlock.gif                 System.Data.DataTable dt
=this.GetTable();
InBlock.gif                
int rc=dt.Rows.Count;
InBlock.gif                
//绘制边框
InBlock.gif
                Range rBorders=(Range)curSheet.get_Range(myExcel.Cells[7,1],myExcel.Cells[7+rc+1,10]);
InBlock.gif                rBorders.Borders.LineStyle
=1;
InBlock.gif                curSheet.get_Range(myExcel.Cells[
7,1],myExcel.Cells[7+rc+1,1]).Borders[XlBordersIndex.xlEdgeLeft].Weight = XlBorderWeight.xlThick;//设置左边线加粗
InBlock.gif
                curSheet.get_Range(myExcel.Cells[7,1],myExcel.Cells[7,10]).Borders[XlBordersIndex.xlEdgeTop].Weight = XlBorderWeight.xlThick;//设置设置上边线加粗
InBlock.gif
                curSheet.get_Range(myExcel.Cells[7+rc+1,1],myExcel.Cells[7+rc+1,10]).Borders[XlBordersIndex.xlEdgeBottom].Weight = XlBorderWeight.xlThick;//设置下边线加粗
InBlock.gif
                curSheet.get_Range(myExcel.Cells[7,10],myExcel.Cells[7+rc+1,10]).Borders[XlBordersIndex.xlEdgeRight].Weight = XlBorderWeight.xlThick;//设置右边线加粗
InBlock.gif
InBlock.gif
InBlock.gif
InBlock.gif                
//Excel的表头信息
InBlock.gif
                myExcel.Cells[1,2]="表头信息";
InBlock.gif
InBlock.gif                myExcel.Cells[
2,2]="New Added:" + DateTime.Now.ToString();
InBlock.gif                myExcel.Cells[
3,4]="VENDOR  CODE  LIST  -  BY  PRODUCTS.";
InBlock.gif                myExcel.Cells[
4,4]="****************************************";
InBlock.gif
InBlock.gif                myExcel.Cells[
5,9]="DATE From:" + DateTime.Now.ToString();
InBlock.gif                myExcel.Cells[
6,9]="DATE To:" + DateTime.Now.ToString();
InBlock.gif
InBlock.gif                myExcel.Cells[
7,5]="PARTS SUPPLIER";
InBlock.gif
InBlock.gif                
//设置Excel表列头
InBlock.gif
                myExcel.Cells[8,1]="Item";
InBlock.gif                myExcel.Cells[
8,2]="OrgCode";
InBlock.gif                myExcel.Cells[
8,3]="VendorCode";
InBlock.gif                myExcel.Cells[
8,4]="VendorName";
InBlock.gif                myExcel.Cells[
8,5]="A";
InBlock.gif                myExcel.Cells[
8,6]="B";
InBlock.gif                myExcel.Cells[
8,7]="C";
InBlock.gif                myExcel.Cells[
8,8]="PayMentType";
InBlock.gif                myExcel.Cells[
8,9]="TermsCode";
InBlock.gif                myExcel.Cells[
8,10]="CreateTime";
InBlock.gif                
//设置表头字体风格
InBlock.gif
                curSheet.get_Range(myExcel.Cells[7,1],myExcel.Cells[8,10]).Font.Bold=true;
InBlock.gif                
int j=1;//j为总结的Item数目的变量
InBlock.gif
                int i=9;
InBlock.gif                
while (i-8<=dt.Rows.Count)
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    myExcel.Cells[i,
1]=j.ToString();
InBlock.gif                    myExcel.Cells[i,
2]=dt.Rows[i-9]["Name"].ToString().Trim();
InBlock.gif                    myExcel.Cells[i,
3]=dt.Rows[i-9]["cost"].ToString().Trim();
InBlock.gif                    myExcel.Cells[i,
4]=dt.Rows[i-9]["bug"].ToString().Trim();
InBlock.gif                    myExcel.Cells[i,
5]="";
InBlock.gif                    myExcel.Cells[i,
6]="";
InBlock.gif                    myExcel.Cells[i,
7]="";
InBlock.gif                    
InBlock.gif                    
//设置颜色,否则日期显示成"######"格式。
InBlock.gif
                    Range rCol10=(Range)myExcel.Cells[i,10];
InBlock.gif                    rCol10
=null;
InBlock.gif                    
//从1开始循环
InBlock.gif
                    j++;
InBlock.gif                    i
++;
ExpandedSubBlockEnd.gif                }
 
InBlock.gif
InBlock.gif                myBook.Saved
=true;
InBlock.gif                myBook.SaveAs(DownloadFilePath,missing2,
"","",false,false,XlSaveAsAccessMode.xlNoChange,1,false,missing,missing,missing);
InBlock.gif
InBlock.gif                myBook.Close(
falsenull,null);
InBlock.gif                myExcel.Quit();
InBlock.gif                System.Runtime.InteropServices.Marshal.ReleaseComObject(myBook);
InBlock.gif                System.Runtime.InteropServices.Marshal.ReleaseComObject(myExcel);
InBlock.gif                myBook 
= null;
InBlock.gif                myExcel 
= null;
InBlock.gif                GC.Collect();
InBlock.gif                
//下载文件
InBlock.gif
                HttpResponse response = HttpContext.Current.Response; 
InBlock.gif                response.Clear();
InBlock.gif                response.WriteFile(DownloadFilePath);
InBlock.gif                
string httpHeader="attachment;filename=backup.Xls";
InBlock.gif                response.AppendHeader(
"Content-Disposition", httpHeader);
InBlock.gif                response.Flush();
InBlock.gif                
//删除临时文件
InBlock.gif
                System.IO.File.Delete(DownloadFilePath);
InBlock.gif                
InBlock.gif                killExcelProcess();
ExpandedSubBlockEnd.gif            }

InBlock.gif            
catch(Exception Ex)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
throw Ex;
ExpandedSubBlockEnd.gif            }

ExpandedSubBlockEnd.gif        }

ExpandedSubBlockStart.gifContractedSubBlock.gif        
/**//// <summary>
InBlock.gif        
/// 删除Excel进程
ExpandedSubBlockEnd.gif        
/// </summary>

ExpandedSubBlockStart.gifContractedSubBlock.gif        private void  killExcelProcess()dot.gif{
InBlock.gif            
//结束 Excel 进程
ExpandedSubBlockStart.gifContractedSubBlock.gif
            foreach(System.Diagnostics.Process xlProcess in System.Diagnostics.Process.GetProcesses())dot.gif{
ExpandedSubBlockStart.gifContractedSubBlock.gif                
if( xlProcess.ProcessName.ToUpper().Equals("EXCEL")) dot.gif{
InBlock.gif                    
//结束 excel 进程 
InBlock.gif
                    xlProcess.Kill();
ExpandedSubBlockEnd.gif                }

ExpandedSubBlockEnd.gif            }

InBlock.gif                
ExpandedSubBlockEnd.gif        }

ExpandedSubBlockStart.gifContractedSubBlock.gif        
/**//// <summary>
InBlock.gif        
/// 构建临时DataTable
InBlock.gif        
/// </summary>
ExpandedSubBlockEnd.gif        
/// <returns></returns>

InBlock.gif        private System.Data.DataTable GetTable()
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            System.Data.DataTable dt 
= new System.Data.DataTable();
InBlock.gif            dt.Columns.Add(
"Name");
InBlock.gif            dt.Columns.Add(
"cost");
InBlock.gif            dt.Columns.Add(
"bug");
InBlock.gif            DataRow rw 
= dt.NewRow();
InBlock.gif            rw[
"Name"]= "";
InBlock.gif            rw[
"Cost"]= "12";
InBlock.gif            rw[
"bug"]= "5";
InBlock.gif            dt.Rows.Add(rw);
InBlock.gif            rw 
= dt.NewRow();
InBlock.gif            rw[
"Name"]= "";
InBlock.gif            rw[
"Cost"]= "15";
InBlock.gif            rw[
"bug"]= "2";
InBlock.gif            dt.Rows.Add(rw);
InBlock.gif            rw 
= dt.NewRow();
InBlock.gif            rw[
"Name"]= "";
InBlock.gif            rw[
"Cost"]= "8";
InBlock.gif            rw[
"bug"]= "1";
InBlock.gif            dt.Rows.Add(rw);
InBlock.gif            
return dt;
ExpandedSubBlockEnd.gif        }

ExpandedSubBlockEnd.gif    }

ExpandedBlockEnd.gif}

None.gif


 

转载于:https://www.cnblogs.com/echo/archive/2005/05/24/161461.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/464542.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Traceroute(路由追踪)的原理及实现

现实世界中的网络是由无数的计算机和路由器组成的一张的大网&#xff0c;应用的数据包在发送到服务器之前都要经过层层的路由转发。而Traceroute是一种常规的网络分析工具&#xff0c;用来定位到目标主机之间的所有路由器 原理 在介绍Traceroute的原理之前&#xff0c;需要了解…

社交网站与网民隐私安全报告(2009)

社交网站与网民隐私安全报告&#xff08;2009&#xff09; 免责声明&#xff1a; 本报告主要内容来自瑞星客户服务中心和瑞星互联网攻防实验室的调查和研究成果&#xff0c;部分数据来自来自瑞星“云安全”系统&#xff0c;仅针对网民在使用国内社交网站&#xff08;SNS&#x…

Intent传递数据时,可以传递哪些类型数据

Intent传递数据时&#xff0c;下列的数据类型哪些可以被传递&#xff08;abcd&#xff09;(多选) A、Serializable B、charsequence C、Parcelable D、Bundle 除了上面的还能传递基本数据类型(byte/boolean/char/short/int/float/long/double)、String/StringBuffer/StringBu…

周记之琢磨下计算机网络(2018/10/22-2018/10/28)

网络&#xff0c;就如同空气一样&#xff0c;我们身处其中&#xff0c;却对它的存在司空见惯&#xff0c;从未察觉&#xff0c;而计算机网络这门课&#xff0c;的确让我看到了它的本来面目&#xff0c;它的五大层次&#xff08;从上往下&#xff09;&#xff1a;应用层、传输层…

我们应该搞清楚分支预测

分支预测的英文名字是「Branch Prediction」大家可以在Google上搜索这个关键字&#xff0c;可以看到关于分支预测的很多内容&#xff0c;不过要搞清楚分支预测如何工作的&#xff0c;才是问题的关键。分支预测对程序的影响我们来看看下面的两段代码代码1#include <algorithm…

Intent介绍及Intent在Activity中的使用方法

1.Intent的实现过程   在Android中&#xff0c;Intent不仅可用于应用程序之间的交互&#xff0c;也可用于应用程序内部的Activity/Service之间的交互。   Intent负责对应用中一次操作进行描述&#xff0c;描述内容包括动作以及动作所涉及的数据&#xff0c;Android中的In…

java 程序中打开文件和文件夹

打开文件 //打开工具的路径及名字 String toolsPath "C:/WINDOWS/system32/notepad.exe "; //被打开文件的路径及名字 String fileName "test.txt"; try { Runtime.getRuntime().exec(toolsPathfileName); } catch (IOException e) { // TODO Aut…

php函数可变参数列表,PHP函数可变参数列表的具体实现方法介绍

也许对于PHP初级程序员来说&#xff0c;对于PHP函数并不能完全熟练的掌握。我们今天为大家介绍的PHP函数可变参数列表的实现方法主要是利用func_get_args()、 func_num_args()、func_get_arg()这三个系统函数来实现的&#xff0c;其中func_get_args()函数以数组的形式获得参数列…

程序结束后去哪儿了?

大家好&#xff0c;我是写代码的篮球球痴&#xff0c;转发一篇卓老师的文章&#xff0c;文章中的内容我之前做单片机的时候也有遇到过。推荐给大家看看~简 介&#xff1a; 对于嵌入式系统&#xff0c;如果没有运行RTOS&#xff0c;那么程序开发中的 主函数&#xff08;main()&a…

CodeSmith终极玩法

CodeSmith是一个模仿asp.net运行机制的代码生成器, 运行时分析模板(相当aspx文件)的预编译指令和主体内容, 生成一个继承自CodeSmith.Engine.CodeTemplate(相当于System.Web.UI.Page)或者一个在Inherites预编译指令指定的类(相当于CodeBehind类)的源码, 且把它编译. 然后把这个…

bom与dom

区别 BOM&#xff08;Browser Object Model&#xff09; BOM 即浏览器对象模型&#xff0c;BOM没有相关标准&#xff0c;BOM的最核心对象是window对象。window对象既为javascript访问浏览器提供API&#xff0c;同时在ECMAScript中充当Global对象。BOM和浏览器关系密切&#xff…

Service 的生命周期;两种启动方法和区别

1&#xff1a;startService Service的生命周期&#xff1a;onCreate() --> onStart() -> onDestroy() 停止服务&#xff1a;service.stopService() 2&#xff1a;bindService Service的生命周期 onCreate() --> onBind() --> onUnBind() --> onDestroy() 停止…

用反射简化 asp.net 报表的一点总结

有几个报表, 查询条件都一样&#xff0c;仅仅里面GridView中有几个列区别&#xff0c;以前图快&#xff0c;就把原来Report.aspx文件拷贝一份&#xff0c;改名为Report1.aspx&#xff0c;然后&#xff0c;修改里面的column&#xff0c;然后再由后台库查出数据&#xff0c;填充到…

超轻型的数据库sqlite

很多次看到别人提到这个东西&#xff0c;最近因项目需要看了看&#xff0c;确实好用。总共就两个文件&#xff0c;我想不能再简单了。还是开源的。开发rails也可以用&#xff0c;不错&#xff01;转载于:https://www.cnblogs.com/chenge/archive/2005/06/29/183508.html

有些事不用听别人的

今天在群里跟几个朋友聊天&#xff0c;然后说了自己的想法&#xff0c;最近很多人在说公众号不会有好的发展&#xff0c;写文章也是没有出路的。不过这个是事实。短视频才是可能是出路&#xff0c;短视频是个很大的蛋糕&#xff0c;从表达方式上来说&#xff0c;视频的表达方式…

php读取三维数组,php 读取多维数组方法_PHP教程

php 读取多维数组方法for($i0;$i{for($j0;$j{echo $array[$j][userid];}}因为它是个多维数组,一般用foreach ($arr as $key > $value) {echo "Key: $key; Value: $value\n";}Array ( [0] > Array ( [userid] > 1 [username] > 刘振鹏 [status] > 0 [u…

互斥锁mutex的使用方法

在线程实际运行过程中&#xff0c;我们经常需要多个线程保持同步。这时可以用互斥锁来完成任务&#xff1b;互斥锁的使用过程中&#xff0c;主要有pthread_mutex_init&#xff0c;pthread_mutex_destory&#xff0c;pthread_mutex_lock&#xff0c;pthread_mutex_unlock这几个函…

1000瓶药水,1瓶有毒药,几只小白鼠能够找出毒药

1000瓶药水&#xff0c;1瓶有毒药&#xff0c;服用后一小时毒发&#xff0c;毒药可以无限稀释&#xff0c;那么一小时内用几只小白鼠能够找出毒药&#xff1f; 假如是8瓶药水&#xff0c;3只小白鼠。 0000  0011  0102  0113  1004  1015  1106  1117 每位数表示…

25个优秀的设计机构网站设计案例

今天&#xff0c;我们一起来欣赏网站设计工作室自己的网站。设计公司的网站除了要能够吸引客户以外&#xff0c;还要通过他们自己的网站向客户展示他们的设计理念和风格。这里收集的25个优秀的设计机构网站既有清爽简洁风格的&#xff0c;也有色彩丰富&#xff0c;图文并茂的&a…

windows server 2003 出错提示请求的资源在使用中解决方案

1.杀毒软件造成IIS站点‘请求的资源在使用中’”的消息&#xff0c;如瑞星2005&#xff0c;服务器上使用单机版杀毒一般都不会稳定的。马上把瑞星卸载了&#xff0c;重启机器&#xff0c;一切正常。 2.IUSR_机器名和IWAM_机器名的账号不同步,这个在网上已经有解决方案了只要打开…