C# 导出word文档及批量导出word文档(1)

这里用到了两个dll,一个是aspose.word.dll,另外一个是ICSharpCode.SharpZipLib.dll,ICSharpCode.SharpZipLib.dll是用于批量导出word文档的,通过把文件打包成压缩包,以文件流的方式输出下载。aspose.word.dll最好使用最新版的,14.5或者更高,我使用的是14.5版本,页面是采用mvc的语法。在这里感谢赵某人为我提供的帮助。         首先制作好word模板,使用模板可以避免在代码中对word进行排版,方便简单。书签和文本域的方法分别说明。

(1)书签

打开word文档,选择“插入” →“书签”,在打开的对话框中输入要添加的书签名,书签名可以随意定义,不过最好是数据表一致,这样在代 码里就减少了判断,然后点击添加,算完成了。书签是看不见的,就隐藏的,但它确确实实存在着,书签的局限性在于:一个word文档里只有一个书签,不能同名,且若获取列表时,书签只能在文档的开头,前面不能插有其它的书签或域,而文本域则不限,但是如果是二维域的话,文档里有相同的两个字段的话,会导致后面的值会被前面的覆盖,比如有两个starttime的二维域,第二个starttime的值为变成第一个的starttime的值,而不是其真正数据表里的值。循环的列表则不会出现这样的情况。所以我用的都是文本域,相关设置如下图:

(2)文本域

打开word文档,将光标放在插入点,选择“插入” →“文档部件”→“域”,在打开的对话框中,选择“邮件合并”→“MergeField”,输入要添加的名称,名称可以随意定义,不过最好是数据表一致,这样在代码里就减少了判断,然后点击确定,算完成了。这里特别要注意的是,定义图片的域的方式,要加Image:,如下图:

以上的书签和域是获取单条记录的,如果是多条记录的话,则需要循环列表并填充数据,相关设置如下:

  • 书签列表,上面的编号,姓名,时间也要插入书签,table是到时循环出来的列表插入的位置:

  • 域,主要是注意tablestart和tableend,标题不用插入域,只需在下一行定义好域即可:

时间: 2024-11-02 12:43:32

C# 导出word文档及批量导出word文档(1)的相关文章

C# 导出word文档及批量导出word文档(3)

在初始化WordHelper时,要获取模板的相对路径.获取文档的相对路径多个地方要用到,比如批量导出时要先保存文件到指定路径下,再压缩打包下载,所以专门写了个关于获取文档的相对路径的类. 1 #region 获取文档的相对路径 2 public class WordFilePath 3 { 4 #region 返回文件带路径值 5 /// <summary> 6 /// 返回文件带路径值 7 /// </summary> 8 /// <param name="Fil

C# 导出word文档及批量导出word文档(2)

aspose.word主要是通过把读取出来的数据放到datatable里,在datable里做相应的格式的调整,再导出到word文档里.mvc和webform最后导出的语句略有不同,在mvc的controller,用的是base.File,对应的是FileContentResult,在webform里用的是Response.写法分别为: //在WebForm中,保存文档到流中,使用Response. BinaryWrite输出该文件 var docStream = new MemoryStrea

lotus notes 数据库中附件的批量导出 2

Lotus Notes 数据库中附件的批量导出 Lotus Notes 数据库是一种文档型数据库,其中文档的富文本域中往往嵌入许多附件(如 Word 文档.PDF 文档.Excel 文档等).用户时常需要将这些附件导出到其他系统中进行使用处理.然而当需要导出许多文档中的附件时,只能手动逐个打开各个文档并将附件导出,然后再将附件导入到其他系统中,那么,当附件数量很大时则会大大降低效率.本文从用户角度出发,分析了若干附件批量导出的需求并给出了相应的解决方案. 引言 Notes 数据库是一种文档型数据

C#操作Word的+ CKEditor 輸出成Word文件(包含圖案上傳)

C#操作Word 参考博文: C#操作word类文件 https://www.cnblogs.com/walking/p/3571068.html C#中的Office操作专栏(21) http://blog.csdn.net/lzhui1987/article/category/6511234 c# 操作Word总结 http://www.cnblogs.com/eye-like/p/4121219.html C#操作WORD公用类 http://blog.csdn.net/liu793185

批量导出access某表内容到word文档

一.需求: 需要将表中每一条记录中的某些内容导出在一个word文档中,并将这些文档保存在指定文件夹目录下 二.界面,简单设计如下: 三.添加office相关引用 添加后可在解决方案资源管理器中看到: 四.添加form1中的引用 using System.Data.OleDb;using System.Data.SqlClient;using System.IO;using Microsoft.Office.Core;using Word=Microsoft.Office.Interop.Word

Asp.net的对Excel文档的导入导出操作

刚刚初入职场,在休闲的时间写下了项目中用到的对Excel文档操作的方法以及总结,多的不说,直接上代码 public static void CreateExcel(DataSet ds, string FileName) { //resp = Page.Response; HttpContext.Current.Response.Clear(); HttpContext.Current.Response.Buffer = true; HttpContext.Current.Response.Ch

Elasticsearch5.0 Java Api(五) -- 批量导出索引

从索引库中将检索到的数据导出到外部文件,文件格式为.json 1 package com.juyun.test; 2 3 import java.io.BufferedWriter; 4 import java.io.File; 5 import java.io.FileWriter; 6 import java.io.IOException; 7 import java.net.InetAddress; 8 import java.net.UnknownHostException; 9 10

使用PHPExcel实现数据批量导出为excel表格

首先需要下载PHPExecel类文件,帮助文档可以参考PHPExcel中文帮助手册|PHPExcel使用方法. 下面直接上例子,是我自己写的一个简单的批量导出数据为excel的例子 前台页面 比较简单,就是一个超链接,跳转到处理页面,超链接也可以跟一些参数(看需求)! <a href="./Process1.php">导出excel表格</a> 后台Process.php页面 /** * 批量导出数据 * @param $arr 从数据库查询出来,即要导出的数据

fusioncharts批量导出图片之后自动提交表单

最近一个项目  一个页面有多个fusioncharts,需要将他们一次性导出之后再利用图片做一下操作,制作一个可以客户下载的质检简报. 对客户效果来说,我只需要点击一个按钮就能生成简报并且下载,对开发人员来说就需要,先将图片导出(当然不能挨个导出,要同时执行导出,因为fusioncharts导出太慢了),要确认全部导出了才能提交表单,要不然提交表单之后,图片没有生成出来必然产生异常.下面我们来看一下实现 首先我给每一个fusionchartschart指定一个有规律的id,作用有两个: 一个是导