Asp.Net 常用工具类之Office-文档操作(6)
文档一直是老大难问题,君不知,代码用时方恨少!有一套成熟的文件帮助类能很大程度上减少寻找各种资料的时间。
记得以前做一个业务,需要导出协议,一份可编辑,一份不可编辑。那么Word和PDF是最好的选择,Word可编辑,PDF只给客户方面看!
前两天复习了一下Excel的操作,主要运用到NPOI组件。
今天给大家带来的是另一个组件Spire.DataExport的使用,主要是进行HTML,Word,PDF的导出操作。
第一次用到Spire.DataExport还是去年上半年的时候。说实话,非常强大,特别是针对于文档的转换和导入导出操作,非常便利,且使用简单,大家有兴趣的可以去官网查看相关资料,Demo非常清晰明了。
DataTable转Word
/// <summary>
/// DataTable导出到Word
/// </summary>
/// <param name="filename">文件名称和路径</param>
/// <param name="dt">dt</param>
/// <param name="isweb">是否web导出</param>
public static void DataTableToWord(string filename, DataTable dt, bool isweb = true)
{
if (dt != null && dt.Rows.Count > )
{
if (filename.IndexOf(".doc", StringComparison.OrdinalIgnoreCase) < && filename.IndexOf(".docx", StringComparison.OrdinalIgnoreCase) < )
filename += ".doc"; RTFExport word = new RTFExport
{
DataSource = Spire.DataExport.Common.ExportSource.DataTable,
DataTable = dt,
ActionAfterExport = Spire.DataExport.Common.ActionType.OpenView
}; using (MemoryStream ms = new MemoryStream())
{
word.SaveToStream(ms);
if (!isweb)
{
if (!filename.Contains("\\"))
filename = Config.Config.GenerateFilePath("Office") + filename; if (!File.Exists(filename))
{
using (FileStream fs = new FileStream(filename, FileMode.CreateNew))
{
fs.Write(ms.ToArray(), , ms.ToArray().Length);
fs.Close();
}
}
}
else
{
HttpContext curContext = HttpContext.Current;
curContext.Response.ContentType = "application/vnd.ms-word";
curContext.Response.ContentEncoding = Encoding.UTF8;
curContext.Response.Charset = "";
curContext.Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(filename, Encoding.UTF8));
curContext.Response.BinaryWrite(ms.GetBuffer());
curContext.Response.End();
}
}
}
}
DataTable转PDF
/// <summary>
/// DataTable导出到PDF
/// </summary>
/// <param name="filename">文件名称和路径</param>
/// <param name="dt">dt</param>
/// <param name="isweb">是否web导出</param>
public static void DataTableToPDF(string filename, DataTable dt, bool isweb = true)
{
if (dt != null && dt.Rows.Count > )
{
if (filename.IndexOf(".pdf", StringComparison.OrdinalIgnoreCase) < )
filename += ".pdf"; Spire.DataExport.PDF.PDFExport pdf = new Spire.DataExport.PDF.PDFExport
{
DataSource = Spire.DataExport.Common.ExportSource.DataTable,
DataTable = dt,
ActionAfterExport = Spire.DataExport.Common.ActionType.OpenView
}; using (MemoryStream ms = new MemoryStream())
{
pdf.SaveToStream(ms);
if (!isweb)
{
if (!filename.Contains("\\"))
filename = Config.Config.GenerateFilePath("Office") + filename; if (!File.Exists(filename))
{
using (FileStream fs = new FileStream(filename, FileMode.CreateNew))
{
fs.Write(ms.ToArray(), , ms.ToArray().Length);
fs.Close();
}
}
}
else
{
HttpContext curContext = HttpContext.Current;
curContext.Response.ContentType = "application/pdf";
curContext.Response.ContentEncoding = Encoding.UTF8;
curContext.Response.Charset = "";
curContext.Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(filename, Encoding.UTF8));
curContext.Response.BinaryWrite(ms.GetBuffer());
curContext.Response.End();
}
}
}
DataTable转HTML
/// <summary>
/// DataTable导出到HTML
/// </summary>
/// <param name="filename">文件名称和路径</param>
/// <param name="dt">dt</param>
/// <param name="isweb">是否web导出</param>
public static void DataTableToHTML(string filename, DataTable dt, bool isweb = true)
{
if (dt != null && dt.Rows.Count > )
{
if (filename.IndexOf(".html", StringComparison.OrdinalIgnoreCase) < )
filename += ".html";
HTMLExport html = new HTMLExport
{
ActionAfterExport = ActionType.None,
HtmlStyle = HtmlStyle.MSMoney,
DataSource = ExportSource.DataTable,
DataTable = dt
}; using (MemoryStream ms = new MemoryStream())
{
html.SaveToStream(ms);
if (!isweb)
{
if (!filename.Contains("\\"))
filename = Config.Config.GenerateFilePath("Office") + filename; if (!File.Exists(filename))
{
using (FileStream fs = new FileStream(filename, FileMode.CreateNew))
{
fs.Write(ms.ToArray(), , ms.ToArray().Length);
fs.Close();
}
}
}
else
{
HttpContext curContext = HttpContext.Current;
curContext.Response.ContentType = "text/html";
curContext.Response.ContentEncoding = Encoding.UTF8;
curContext.Response.Charset = "";
curContext.Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(filename, Encoding.UTF8));
curContext.Response.BinaryWrite(ms.GetBuffer());
curContext.Response.End();
}
}
}
}
OK,各位看官,近期的文档操作写到这里喏,感谢大家的支持,您的支持是我的动力!
下一期给大家带来的是Config文件操作,敬请期待!!!
Asp.Net 常用工具类之Office-文档操作(6)的更多相关文章
- Asp.Net 常用工具类之Office—Excel导入(5)
之前在做一个项目的时候,客户方面只提供了一份简单的Excel文件,且要跟现有数据进行对接. 当时想到的是如果数据量不大,可以Excel一条一条加进去,无奈数据有几十兆!!! 换了一种思维,进行了导入: ...
- Asp.Net 常用工具类之Office—Excel导出(4)
开发过程中各类报表导入导出防不胜防,网上也是各种解决方法层出不穷,比如Excel,CSV,Word,PDF,HTML等等... 网上各种导出插件也是层出不穷,NPOI,微软Microsoft.Offi ...
- Java,面试题,简历,Linux,大数据,常用开发工具类,API文档,电子书,各种思维导图资源,百度网盘资源,BBS论坛系统 ERP管理系统 OA办公自动化管理系统 车辆管理系统 各种后台管理系统
Java,面试题,简历,Linux,大数据,常用开发工具类,API文档,电子书,各种思维导图资源,百度网盘资源BBS论坛系统 ERP管理系统 OA办公自动化管理系统 车辆管理系统 家庭理财系统 各种后 ...
- java基础课程笔记 static 主函数 静态工具类 classpath java文档注释 静态代码块 对象初始化过程 设计模式 继承 子父类中的函数 继承中的构造函数 对象转型 多态 封装 抽象类 final 接口 包 jar包
Static那些事儿 Static关键字 被static修饰的变量成为静态变量(类变量) 作用:是一个修饰符,用于修饰成员(成员变量,成员方法) 1.被static修饰后的成员变量只有一份 2.当成员 ...
- 常用工具说明--jsdoc 前端文档输出工具
1.利用npm安装jsdoc模块 npm install jsdoc -g 2.由于jsdoc默认的生成文档模板不好看,可以下载一套好看些的模板,如 jaguar.js 下载地址:https:// ...
- Asp.Net 常用工具类---Config操作(7)
近期工作比较忙,忙到忘记写博客(自己的借口,主要加班下班后不想动). 月初的时候,打算每两天写一篇博文,分享自己的一些心得和开发体验,无奈现在只写到第六篇,然而时间已经是20号,岁月不饶人! 总想写点 ...
- Asp.Net 常用工具类之加密——非对称加密RSA算法
踏入程序员这个行业也有几年了,几年中有收获(技术加强),有付出(时间和亚健康状态).当然喏,并不后悔,代码路还长!!! On The Way,永不止步!!! 开发过程中也积累了一些自己的经验.代码块和 ...
- Asp.Net 常用工具类之加密——对称加密DES算法(2)
又到周末,下午博客园看了两篇文章,关于老跳和老赵的程序员生涯,不禁感叹漫漫程序路,何去何从兮! 转眼毕业的第三个年头,去过苏州,跑过上海,从一开始的凌云壮志,去年背起行囊默默回到了长沙准备买房,也想有 ...
- [C#] 常用工具类——文件操作类
/// <para> FilesUpload:工具方法:ASP.NET上传文件的方法</para> /// <para> FileExists:返回文件是否存在&l ...
随机推荐
- iOS 之 Block Variable
在某个变量前面加__block ,这个变量就变成了block variable.那么就可以在block里面修改该值.
- DDOS攻击(流量攻击)防御步骤
DDOS全名是Distributed Denial of service (分布式拒绝服务攻击),很多DOS攻击源一起攻击某台服务器就组成了DDOS攻击,DDOS 最早可追溯到1996年最初,在中国2 ...
- 星级评分条(RatingBar)的功能和用法
星级评分条与拖动条有相同的父类:AbsSeekBar,因此它们十分相似.实际上星级评分条与拖动条的用法.功能都十分接近:它们都是允许用户通过拖动条来改变进度.RatingBar与SeekBar最大区别 ...
- 记一次DG搭建过程中备库ORA-00210,ORA-00202,ORA-27086错误
ORA-00210: cannot open the specified control file ORA-00202: control file: '/u01/app/oracle/oradata/ ...
- java程序的工作原理
Sun公司设计java语言的目标是让Java程序不必经过修改就可以在各种各样的计算机(包括PC机和工作站)上运行.为了实现这一目标,Sun公司提供了一阵Java虚拟机(Java Virtual Mac ...
- [TPYBoard-Micropython教程之1] 运行第一个脚本——点亮LED
转载请注明:@小五义http://www.cnblogs.com/xiaowuyiQQ群:64770604 会python就能做硬件! 一.TPYBoard V102开发板 TPYBoard V102 ...
- 解决IIE8不支持媒体查询的方法
最近在解决UI问题时碰到以下浏览器不兼容性问题(本人属于UI业余操作者,很多想法就很业余了): 问题:IE8及其以下低版本IE浏览器在缩小窗口时,UI没有按照相应的要求显示窗口缩小时对应的布局:其他浏 ...
- 1.使用SignalR实现页面即时刷新(服务端主动推送)
模块功能说明: 实现技术:sqlserver,MVC,WebAPI,ADO.NET,SignalR(服务器主动推送) 特殊车辆管理--->移动客户端采集数据存入数据库---->只要数据库数 ...
- windows下部署免费ssl证书(letsencrypt)
随着网络的发展,网络安全也越来越重要,对于网站来说,从Http升级到https也是我们要做的首要事情.要实现https,首先我们需要申请一张SSL证书,这篇文章我主要介绍下边这几个方面: 1. SSL ...
- PPT中翻书动画的制作
一.新建一个空白的PowerPoint文档. 二.制作两个页面: 1.点击“自选图形”右边的小三角,选择“基本图形”下的“折角形”图形,在PowerPoint中画出一个书页样的图形,宽度最好小 ...