使用NPOI2.1.3.1版本导出word附带表格和图片
原文:http://www.cnblogs.com/afutureBoss/p/4074397.html?utm_source=tuicool&utm_medium=referral
最近项目需要用到导出word,巨硬的office组件,大多数人都不喜欢用(我就其中之一)。所有在网上尝试了几个插件。能够导出word的,除了NPOI之外,还有docX(免费),pageoffice(收费),aspose(也是收费的,虽然我有license,但是公司的另一个项目组用了破解版的,导致我也不敢用。毕竟license也是网上down下来的。)收费的,我想大家伙儿和我一样都不会去考虑,所有我只是尝试了一下docX,docX的代码量相对于NPOI来说少很多,但是这货中文的资料太少了(鄙视一下CSDN,妈蛋,是个用户写个代码就往上传,还他丫的下载一个10个积分……),捣腾了半天,最终能够生成word,但是要是往里面加图片,确实不知道怎弄。(如果你有幸看了这篇文字,并且还会,还望不吝)。
NPOI这个东西好是好,但是有个问题,如果不说,可能很多人都不会注意。它的版本总是让人感到错愕。一个不一样的版本,写法就会产生很多变化,下面代码中,注释掉的部分,就是因为引用的版本发生变化,改写了部分代码。
protected void Button1_Click(object sender, EventArgs e)
{
XWPFDocument doc = new XWPFDocument(); //创建新的word文档
XWPFParagraph p0 = doc.CreateParagraph(); //向新文档中添加段落
p0.Alignment = ParagraphAlignment.LEFT;
//p0.SetAlignment(ParagraphAlignment.LEFT); //段落对其方式为居中
XWPFRun r0 = p0.CreateRun();
r0.FontFamily = "宋体";
//r0.SetFontFamily("宋体");
r0.FontSize = ;
//r0.SetFontSize(20);
r0.SetBold(true);
r0.SetText("未登录过学生的账号密码");//向该段落中添加文字
XWPFParagraph p1 = doc.CreateParagraph();
p1.Alignment = ParagraphAlignment.LEFT;
//p1.SetAlignment(ParagraphAlignment.LEFT);
XWPFRun r1 = p1.CreateRun();
r1.FontFamily = "宋体";
//r1.SetFontFamily("宋体");
r1.FontSize = ;
//r1.SetFontSize(15);
r1.SetBold(true);
r1.SetText("(备注:已登录过的学生密码不显示)");
XWPFParagraph p2 = doc.CreateParagraph();
p2.Alignment = ParagraphAlignment.LEFT;
//p2.SetAlignment(ParagraphAlignment.LEFT);
XWPFRun r2 = p2.CreateRun();
//r2.SetFontFamily("宋体");
r2.FontFamily = "宋体";
//r2.SetFontSize(10);
r2.FontSize = ;
r2.SetBold(true);
r2.SetText("学校:XX一中");
XWPFParagraph p3 = doc.CreateParagraph();
p3.Alignment = ParagraphAlignment.LEFT;
//p3.SetAlignment(ParagraphAlignment.LEFT);
XWPFRun r3 = p2.CreateRun();
//r3.SetFontFamily("宋体");
r3.FontFamily = "宋体";
//r3.SetFontSize(10);
r3.FontSize = ;
r3.SetBold(true);
r3.SetText("班级:(7)");
XWPFParagraph p4 = doc.CreateParagraph();
p4.Alignment = ParagraphAlignment.LEFT;
//p4.SetAlignment(ParagraphAlignment.LEFT);
XWPFRun r4 = p4.CreateRun();
r4.FontFamily = "宋体";
//r4.SetFontFamily("宋体");
r4.FontSize = ;
//r4.SetFontSize(10);
r4.SetBold(true);
r4.SetText("班主任:ddd");
XWPFParagraph p5 = doc.CreateParagraph();
p5.Alignment = ParagraphAlignment.LEFT;
//p5.SetAlignment(ParagraphAlignment.LEFT);
XWPFRun r5 = p5.CreateRun();
r5.FontFamily = "宋体";
//r5.SetFontFamily("宋体");
r5.FontSize = ;
//r5.SetFontSize(10);
r5.SetBold(true);
r5.SetText("可以在此处添加备注:");
XWPFTable table = doc.CreateTable(, );
table.Width = ;//设置表格宽度
XWPFParagraph pIO = table.GetRow().GetCell().AddParagraph();
XWPFRun rIO = pIO.CreateRun();
rIO.FontFamily = "微软雅黑";
//rIO.SetFontFamily("微软雅黑");
rIO.FontSize = ;
//rIO.SetFontSize(12);
rIO.SetBold(true);
rIO.SetText("表格第一行第一列");
XWPFParagraph pINo = table.GetRow().GetCell().AddParagraph();
XWPFRun rINo = pINo.CreateRun();
//rINo.SetFontFamily("微软雅黑");
rINo.FontFamily = "微软雅黑";
//rINo.SetFontSize(12);
rINo.FontSize = ;
rINo.SetBold(true);
rINo.SetText("表格第一行第二列");
XWPFParagraph pIMm = table.GetRow().GetCell().AddParagraph();
XWPFRun rIMm = pIMm.CreateRun();
//rIMm.SetFontFamily("微软雅黑");
rIMm.FontFamily = "微软雅黑";
//rIMm.SetFontSize(12);
rIMm.FontSize = ;
rIMm.SetBold(true);
rIMm.SetText("表格第一行第三列");
XWPFParagraph pIName = table.GetRow().GetCell().AddParagraph();
XWPFRun rIName = pIName.CreateRun();
//rIName.SetFontFamily("微软雅黑");
rIName.FontFamily = "微软雅黑";
//rIName.SetFontSize(12);
rIName.FontSize = ;
rIName.SetBold(true);
rIName.SetText("表格第一行第4列");
/*这段代码是插入图片的*/
XWPFParagraph gp = doc.CreateParagraph();
XWPFRun gr = gp.CreateRun();
var widthEmus = (int)(400.0 * );
var heightEmus = (int)(300.0 * );
using (FileStream picData = new FileStream("f:\\1.jpg", FileMode.Open, FileAccess.Read))
{
gr.AddPicture(picData, (int)PictureType.PNG, "11.png", widthEmus, heightEmus);
}
/*这段代码是插入图片的*/
FileStream sw = File.Create("cutput.docx"); //写流
doc.Write(sw); //...
sw.Close(); //在服务端生成文件
FileInfo file = new FileInfo("cutput.docx");//文件保存路径及名称 //注意: 文件保存的父文件夹需添加Everyone用户,并给予其完全控制权限
Response.Clear();
Response.ClearHeaders(); //清除报文头
Response.Buffer = false; //不适用页面缓存
Response.ContentType = "application/octet-stream"; //定义传入类型:二进制
Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode("1.docx", System.Text.Encoding.UTF8));//导出的word文档的名字
Response.AppendHeader("Content-Length", file.Length.ToString());
Response.WriteFile(file.FullName);
Response.Flush(); //以上将生成的word文件发送至用户浏览器
File.Delete("cutput.docx"); //清除服务端生成的word文件 }
使用NPOI2.1.3.1版本导出word附带表格和图片的更多相关文章
- C#通过模板导出Word(文字,表格,图片)
C#通过模板导出Word(文字,表格,图片) C#导出Word,Excel的方法有很多,这次因为公司的业务需求,需要导出内容丰富(文字,表格,图片)的报告,以前的方法不好使,所以寻找新的导出方法, ...
- .net使用AsposeWord导出word table表格
本文为原创,转载请注明出处 1.前言 .net平台下导出word文件还可以使用Microsoft.Office.Interop和NPOI,但是这两者都有缺点,微软的Office.Interop组件需要 ...
- word模板导出的几种方式:第二种:C#通过模板导出Word(文字,表格,图片) 占位符替换
原文出处:https://www.cnblogs.com/ilefei/p/3508463.html 一:模板的创建 (注意文件后缀只能是.docx或.doct) 在需要位置 插入-文档部件-域, ...
- 【转】Word之表格、图片的题注(抬头)自动编号
问:word中的表格怎么自动插入题注(即表头的编号自动编号)? 答: 1首先搞清楚自动编号的意思.自动插入题注的意思是,在你在word中新建或者复制一个word表格的时候,表头的编号就自动生成了,而不 ...
- 前台导出Word文档思路步骤总结(freemarker)
1. 需求是导出word带表格,表格列数不变,行数由数据库的值决定: 2. 导出最开始想的是直接前端导出,使用了jquery-wordexport插件,导出后,表格边框全没了,无法使用: 3. 采用了 ...
- Asp.net通过模板(.dot/Html)导出Word,同时导出图片
一.Office组件导出Word(服务器配置麻烦) 需要引用Office的DLL,在下文的附件中,不同的Offic版本用的不一样,虽然高级版本可以兼容低级的,不过,还是统一版本最好 贴上核心代码(转载 ...
- Java导出Word利用freemarker(含图片)
制作Word模版 建议使用高版本的office做,尽量不要用WPS做,生成xml会出现乱码 编码要统一,推荐UTF-8 建好模板,将模板另存为xml格式,建议原来模板不要删,xml的如果后期打不开,还 ...
- NPOI导出word,以及对table的一些设置
参考网址:http://www.aiuxian.com/article/p-1970779.html NPOI版本:2.1.3.1 最终效果图: 代码: /// <summary> /// ...
- C# 导出word文档及批量导出word文档(1)
这里用到了两个dll,一个是aspose.word.dll,另外一个是ICSharpCode.SharpZipLib.dll,ICSharpCode.SharpZipLib.dll是用于批量 ...
随机推荐
- <-0基础学python.第2课->
今天闲着无聊,有想鼓捣Python了,想实现网络爬虫,帮我下载音乐的功能. 现在网上找了相关的一些文章教程 http://jecvay.com/2014/09/python3-web-bug-seri ...
- Birt导出Excel图片
有一段时间没有使用Birt了,最近突然之间发现新版的Birt可以支持导出Excel附带图片.我目前下载的是Birt 4.3版本的,导出图片的也只能在Excel 2007下面能够实现,2003的xls格 ...
- 百度echart使用心得,百度图表。
百度echart算是百度针对数据展示做的一个图表插件吧,一般我们使用都不是问题,主要还是对于对动态数据的解析.我这里使用饼状图,和柱状图为例: 首先,我们需要定义一个绘图的容器:(class是我自己定 ...
- chrome livestyle插件
1.sublime 安装 >step1: ctrl+shift+p >step2:ip >step3:livestyle >step4:配置ho ...
- MacOS changed System Integrity Protection status
禁止 System Integrity Protection 按住 command + R 重启系统 进入单用户模式 启动bash工具: 输入: csrutil disable 输入:reboot 启 ...
- 两种open()函数
C语言中文件操作函数中,open()有两种形式: 一种形式是有两个参数open2: 另一种形式是有三个参数open3: 共有的参数有两个,第一个是"被打开文件的路径",第二个是&q ...
- SQL Server提高事务复制效率优化(三)订阅初始化优化
初始化订阅主要是由分发代理分发和应用快照代理之前生成的快照,所以优化的主体是分发代理. 1.初始化订阅 首先在本地创建一个订阅,发布服务器.分发服务器和订阅服务器都在同一台服务器上,仅为了测试生产环境 ...
- Unity3D 学习——入门资料整理
感觉可以写3D游戏,还是用C#,很好玩的样子.整理最近学习资料 介绍:游戏引擎,可以用C#配置的游戏引擎.嗯,就这样.其余度娘. 安装:官网,因为现在个人版是免费的.直接官网下.干净利落. 调试插件: ...
- delpin常用函数
if r>570 then SET_TT(1);//超出多少行就用excel导出 类似数组用法:var ts: TStringlist;begi ...
- require.js 入门笔记
网站越来越庞大,JS也是越写越多. 当所有的JS 都集中在 HTML的 head 部分时,网页加载变得很慢,很多的 JS代码也并不是全都适用在当前的页面,造成了代码的冗余度非常高. 而且长长的JS代码 ...