时间:2021-05-28
今天研究了一下.net下实现Word动态填加数据打印的做法,觉得颇有收获~
以前做过Excel相关的东西,所以对OFFICE的COM有一些了解,很顺利的找到了需要引用的COM和其帮助文档~具体做法是在引用里添加COM--------Microsoftword11.0objectlibrary,然后引入命名空间:
复制代码 代码如下:
usingWordApplication=Microsoft.Office.Interop.Word.Application;
usingDocument=Microsoft.Office.Interop.Word.Document;
usingBookmark=Microsoft.Office.Interop.Word.Bookmark;
具体实现代码:
WordApplicationword=null;
///<summary>
///实现动态添加数据打印预览
///</summary>
///<paramname="path">word模板路径</param>
///<paramname="adStu">调剂学生相关信息对象</param>
privatevoidPrintPreview(stringpath,AdStuInfoadStu)
...{
if(word==null)
...{
word=newWordApplication();
}
objectoMissing=System.Reflection.Missing.Value;//这个东西找了好久,不像操作Excel,用Type.mising还不行.
objectpath1=(object)path;
Documentdoc=null;
doc=word.Documents.OpenOld(refpath1,refoMissing,refoMissing,refoMissing,refoMissing,refoMissing,refoMissing,refoMissing,refoMissing,refoMissing);
替换书签#region替换书签
objectmarkName="报考单位";
Bookmarkbm=doc.Bookmarks.get_Item(refmarkName);
bm.Range.Text=adStu.SiSch;
markName="报考专业";
bm=doc.Bookmarks.get_Item(refmarkName);
bm.Range.Text=adStu.SiMa;
markName="考生姓名1";
bm=doc.Bookmarks.get_Item(refmarkName);
bm.Range.Text=adStu.Name;
markName="考生编号";
bm=doc.Bookmarks.get_Item(refmarkName);
bm.Range.Text=adStu.No;
markName="调剂专业";
bm=doc.Bookmarks.get_Item(refmarkName);
bm.Range.Text=adStu.AdMa;
markName="打印时间";
bm=doc.Bookmarks.get_Item(refmarkName);
bm.Range.Text=GetDate().ToString();
markName="考生姓名2";
bm=doc.Bookmarks.get_Item(refmarkName);
bm.Range.Text=adStu.Name;
#endregion
word.Visible=true;
doc.PrintPreview();
}
具体解释:首先有一个模板.doc文件,在该模板内需要添加数据的地方设置成书签,.net程序所要的事情就是打开该模板,用具体需要添加的值去替换先设定好的书签,然后返回Word的打印预览页面,思路很简单~但是问题也是有滴~~
这个程序是做打印我们学院研究生办发复试生调卷函用的,但是表格是从学校研究生部那弄来的,主要还是在那边盖的章~所以就只能用那些表格来打,但是给的表格留的空实在太小,没法用同样的字体给打上去,怪就只能怪研究生部根本没想到我们这会有这个高级的东西~~哈哈~估计一般都是手工填的~~~明天过去不知道具体要怎么弄,估计这东西在打印调卷函是发挥不出作用了~~~留着以后肯定有用!
4月16日修改:
几天前做的仔细想想还是有需要改进的地方.我前面做的只是一个个文档的填,一个个的打印,考虑资料上百个以后这样做打印机的打印的效率不高,因为每次只给打印机发送一个打印任务,它接受下一个任务是需要时间的,所以我的想法是把需要打印的文档生成成一个文档,这样不但可以保存文档,还可以只要向打印机发送一个任务就可以打印资料了,NB的打印机打印速度是很快的~~
把具体的操作写下来吧~思路是打开两个word文档(当然,生成过程中全不可见),一个还是按照前面说的替换书签,但是不做打印处理,而是复制到另外一个文档(该文档存储所有已经生成好的表格,最后得到的就是这个word文档,打印或者保存随便他们).具体的代码如下:
先在using里引如:
usingRange=Microsoft.Office.Interop.Word.Range;
doc.Content.Copy();//复制doc里的内容,doc是每次做替换书签的文档.
objectsave=false;
doc.Close(refsave,refoMissing,refoMissing);//关闭doc.
Rangerange=printDoc.Content;//全中printDoc里的全部内容,printDoc是目标保存文档.
range.Collapse(refoMissing);//确定粘贴的位置,其实这个地方我想放一个有效的参数,把粘贴的位置设为文档的末尾,而不是用默认的文档的最前面,但是帮助文档是VB写的,传了一个Direction:=wdCollapseEnd的东东,我弄半天没弄出来,亏我还是懂VB的~~伤心~以至于我都忘了传个空值过去,卡了老半天!谢谢某人和我发了几条短信,就一下把我打通了~
range.Paste();//粘贴到目标位置,一次填写就完成了.
虽然是这样,但是在生成目标文档的时候也是很耗资源的,我看了一下那程序竟然占了100多M的内存!!而且~~而且~~我的机器在前两次实验都没顶住!死机了~~当时真是在抓狂了~谁知道后来几次竟然无声无息的成功!可是想想学院那机器能扛住么~~哎继续优化吧!这次把界面也改了一下,上面的生成在一的单独线程里,以至于主界面不会像死了样的,而且在主界面上还做了个显示生成状态的Lable,这东西还真管用~后面两次的实验,看着已生成数目超过前两次死机的数目~~紧张的心情缓解了~再看着数目超过100~~高兴了~最后慢慢接近完成数目时~~兴奋得抓狂!!!!!哈~~
哎~废话多了点~有用的就那么几行代码~
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
javascript为下拉列表添加数据项.html复制代码代码如下:为下拉列表动态添加数据项functiongel(id){returndocument.get
jqueryAjax实现Select动态添加数据,具体内容如下1.背景最近在工作中,遇到了一个关于select的问题。一般情况下,select下拉框中的数据都是
你可能得预先了解实现功能:点击页面上的按钮实现动态追加数据实现原理:点击页面按钮,通过Ajax提交请求到后台,后台接收请求后进行数据库操作,然后返回数据到前台并
本文实例讲述了jQuery实现表单动态添加数据并提交的方法。分享给大家供大家参考,具体如下:情景1:已经存在form对象了,动态为form增加对象并提交func
本文实例讲述了Java动态数组添加数据的方法与应用。分享给大家供大家参考,具体如下:输入客户的姓名,客户的人数不定。待输入完成后,请打印出客户的名单,并定义一个