页面导入导出EXCEL
引用
using Microsoft.Office.Interop.Excel;
using System.Reflection;//反射命名空间
using System.IO;
protected void Button1_Click(object sender, EventArgs e)
{
//项目引入Microsoft.office.Excel组件
//导出二大部分
//第一部分,生成EXCEL文件
//对象1 应用程序对象
Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
//对象2 工作薄对象
Workbook book = excel.Workbooks.Add(Missing.Value);
//对象3 工作表对象(工作薄中的第一个工作表)
Worksheet worksheet = (Worksheet)book.Worksheets[1];
////////////////////////////////////////////////////////////////////////////////////////
worksheet.Name = "N-Tier";
worksheet.Cells[5, 6] = "欢迎学习 N-Tier";//注意定义单元格中的方法
worksheet.get_Range("A2", Missing.Value).Value2 = "星期";
worksheet.get_Range("A2", Missing.Value).Font.Name = "黑体";
worksheet.get_Range("A2", Missing.Value).Font.Size = 14;
worksheet.get_Range("A2", Missing.Value).RowHeight = 28;
worksheet.get_Range("A1", "Y1").MergeCells = true;//合并单元格
worksheet.get_Range("A1", "Y1").Value2 = "教室机房周占用表";
worksheet.get_Range("A1", "Y1").HorizontalAlignment = Microsoft.Office.Interop.Excel.XlHAlign.xlHAlignCenter;
worksheet.get_Range("A1", "Y1").VerticalAlignment = Microsoft.Office.Interop.Excel.XlVAlign.xlVAlignBottom;
worksheet.get_Range("A1", "Y1").Font.Bold = true;
worksheet.get_Range("A1", "Y1").Font.Name = "黑体";
worksheet.get_Range("A1", "Y1").Font.Size = 20;
worksheet.get_Range("A1", "Y1").RowHeight = 63;
///////////////////////////////////////////////////////////////////////////
//保存EXCEL部分
excel.Visible = false;//应用程序可见
//Excel文件名
string excelName = Server.MapPath("~/temp/")+DateTime.Now.ToString("yyyyMMdd-hhmmss")+".xls";
excel.ActiveWorkbook.SaveAs(excelName, Missing.Value, Missing.Value, Missing.Value, Missing.Value
, Missing.Value, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange, Missing.Value, Missing.Value
, Missing.Value, Missing.Value, Missing.Value);
//关闭工作薄
excel.ActiveWorkbook.Close(true, Missing.Value, Missing.Value);
//退出应用程序
excel.Quit();
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//第二部分,把生成EXCEL文件下载
DownLoadFile(excelName, "学生信息表.xls", this);
/////////////////////////////////////////////////////////////////
}
#region DownLoadFile
/// <summary>
/// 下载所有类型文件通用
/// </summary>
/// <param name="fileName">文件的虚拟路径</param>
/// <param name="downFileName">新名称</param>
/// <param name="page">下载的页面对象</param>
public void DownLoadFile(string fileName, string downFileName, Page page)
{
//清除缓冲区中的所有HTML输出
page.Response.Clear();
page.Response.Buffer = true;
//设置输出流的HTTP字符集
page.Response.Charset = "utf-8";
//attachment参数表示作为附件下载
string attachment = "attachment; filename=" + HttpUtility.UrlEncode(downFileName, System.Text.Encoding.UTF8);
page.Response.AddHeader("content-disposition", attachment);
//设置输出流的HttpMIMe类型(以流形式输出)
page.Response.ContentType = "application/octent-stream";
page.Response.WriteFile(fileName);
page.Response.End();
}
#endregion
protected void Button2_Click(object sender, EventArgs e)
{
//项目引入Microsoft.office.Excel组件
//导出二大部分
//第一部分,生成EXCEL文件
//对象1 应用程序对象
Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
//对象2 工作薄对象
Workbook book = excel.Workbooks.Add(Missing.Value);
//对象3 工作表对象(工作薄中的第一个工作表)
Worksheet worksheet = (Worksheet)book.Worksheets[1];
////////////////////////////////////////////////////////////////////////////////////////
DataClassesDataContext datacontext = new DataClassesDataContext();
var stusList = datacontext.Student.ToList();
for (int i = 0; i <stusList.Count; i++)
{
worksheet.Cells[i + 1, 1] = stusList[i].Name;
worksheet.Cells[i + 1, 2] = stusList[i].Sex;
}
///////////////////////////////////////////////////////////////////////////
//保存EXCEL部分
excel.Visible = false;//应用程序可见
//Excel文件名
string excelName = Server.MapPath("~/temp/") + DateTime.Now.ToString("yyyyMMdd-hhmmss") + ".xls";
excel.ActiveWorkbook.SaveAs(excelName, Missing.Value, Missing.Value, Missing.Value, Missing.Value
, Missing.Value, Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange, Missing.Value, Missing.Value
, Missing.Value, Missing.Value, Missing.Value);
//关闭工作薄
excel.ActiveWorkbook.Close(true, Missing.Value, Missing.Value);
//退出应用程序
excel.Quit();
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//第二部分,把生成EXCEL文件下载
DownLoadFile(excelName, "ss学生信息表.xls", this);
}
页面导入导出EXCEL的更多相关文章
- thinkphp导入导出excel表单数据
在PHP项目经常要导入导出Excel表单. 先去下载PHPExcel类库文件,放到相应位置. 我在thinkphp框架中的位置为ThinkPHP/Library/Org/Util/ 导入 在页面上传e ...
- jxl导入/导出excel
1.jxl导入/导出excel案例,黏贴即可运行 package junit.test; import java.io.File; import java.io.IOException; import ...
- 使用PHPExcel导入导出excel格式文件
使用PHPExcel导入导出excel格式文件 作者:zccst 因为导出使用较多,以下是导出实现过程. 第一步,将PHPExcel的源码拷贝到项目的lib下 文件包含:PHPExcel.ph ...
- NPOI导入导出Excel
.net mvc利用NPOI导入导出excel 注意:如何导出的提交方式ajax导出是失效的! 解决方案是:js处理l两个表单的提交 代码: 第一步. 在页面里面加入2个隐藏的iframe, 如下 ...
- jxl导入/导出excel(网上的案例)
jxl导入/导出excel 1.jxl导入/导出excel案例,黏贴即可运行 package junit.test; import java.io.File; import java.io.IOExc ...
- C#中缓存的使用 ajax请求基于restFul的WebApi(post、get、delete、put) 让 .NET 更方便的导入导出 Excel .net core api +swagger(一个简单的入门demo 使用codefirst+mysql) C# 位运算详解 c# 交错数组 c# 数组协变 C# 添加Excel表单控件(Form Controls) C#串口通信程序
C#中缓存的使用 缓存的概念及优缺点在这里就不多做介绍,主要介绍一下使用的方法. 1.在ASP.NET中页面缓存的使用方法简单,只需要在aspx页的顶部加上一句声明即可: <%@ Outp ...
- asp.net core web的导入导出excel功能
这里主要记录下asp.net core web页面上进行导入导出excel的操作. 主要是导入,因为现在使用的很多前端框架(例如kendo ui)本身就有导出的功能. 这里使用到EPPlus.Core ...
- Vue框架下实现导入导出Excel、导出PDF
项目需求:开发一套基于Vue框架的工程档案管理系统,用于工程项目资料的填写.编辑和归档,经调研需支持如下功能: Excel报表的导入.导出 PDF文件的导出 打印表格 经过技术选型,项目组一致决定通过 ...
- uniapp导入导出Excel
众所周知,uniapp作为跨端利器,有诸多限制,其中之一便是vue页面不支持传统网页的dom.bom.blob等对象. 所以,百度上那些所谓的导入导出excel的方法,大部分都用不了,比如xlsx那个 ...
随机推荐
- Spark练习之action操作开发
Spark练习之action操作开发 一.reduce 1.1 Java 1.2 Scala 二.collect 2.1 Java 2.2 Scala 三.count 3.1 Java 3.2 Sca ...
- 小白搭建WAMP详细教程---apache、mysql、php的整合配置
Apache与PHP整合 我们之前说过PHP能够解析PHP代码, 可是不服务于apache,apache能够获取接收浏览器的请求, 可是不能处理PHP代码, 要实现动态站点开发,就必须结合apache ...
- 深度学习论文翻译解析(十九):Searching for MobileNetV3
论文标题:Searching for MobileNetV3 论文作者:Andrew Howard, Mark Sandler, Grace Chu, Liang-Chieh Chen, Bo Che ...
- Hive调优相关
前言 Hive是由Facebook 开源用于解决海量结构化日志的数据统计,是基于Hadoop 的一个数据仓库工具,可以将结构化的数据文件映射为一张表,并提供类 SQL查询功能. 在资源有限的情况下,提 ...
- 国产smartbits版本-minismb如何测试路由器III
Minismb测试仪表是复刻smartbits的国产版本,是一款专门用于测试智能路由器,网络交换机的性能和稳定性的软硬件相结合的工具.可以通过此工具测试任何ip网络设备的端口吞吐率,带宽,并发连接数和 ...
- CS144学习(1)Lab 0: networking warmup
CS144的实验就是要实现一个用户态TCP协议,对于提升C++的水平以及更加深入学习计算机网络还是有很大帮助的. 第一个Lab是环境配置和热身,环境按照文档里的配置就行了,前面两个小实验就是按照步骤来 ...
- codeforces 6D
D. Lizards and Basements 2 time limit per test 2 seconds memory limit per test 64 megabytes input st ...
- 前端接收后端文件流导出excel文档遇到的问题
先上代码: Vue.prototype.download = function(oUrl, filename) { this.axios .get(oUrl, { responseType: 'arr ...
- 深入理解gradle中的task
目录 简介 定义task tasks 集合类 Task 之间的依赖 定义task之间的顺序 给task一些描述 task的条件执行 task rule Finalizer tasks 总结 深入理解g ...
- 网站资源被盗链的:预防方法 VS 网站资源防盗链的:破解技巧
1 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问! 1 资源被盗链:(简明定义) 下载者不是从你的网站直接下载资源,而是通过其他盗链网站提供的你的下载资源链接进行下载你的服务 ...