天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

.net下實(shí)現(xiàn)Word動(dòng)態(tài)填加數(shù)據(jù)打印

今天研究了一下.NET下實(shí)現(xiàn)Word動(dòng)態(tài)填加數(shù)據(jù)打印的做法,覺(jué)得頗有收獲~
      以前做過(guò)Excel相關(guān)的東西,所以對(duì)OFFICE的COM有一些了解,很順利的找到了需要引用的COM和其幫助文檔~具體做法是在引用里添加 COM --------Microsoft word 11.0 object library, 然后引入命名空間:
復(fù)制代碼 代碼如下:
using WordApplication = Microsoft.Office.Interop.Word.Application; 
using Document = Microsoft.Office.Interop.Word.Document; 
using Bookmark = Microsoft.Office.Interop.Word.Bookmark; 
具體實(shí)現(xiàn)代碼: 

WordApplication word = null; 
 /**//// <summary> 
 /// 實(shí)現(xiàn)動(dòng)態(tài)添加數(shù)據(jù)打印預(yù)覽 
 /// </summary> 
/// <param name="path">word模板路徑</param> 
/// <param name="adStu">調(diào)劑學(xué)生相關(guān)信息對(duì)象</param> 
private void PrintPreview(string path, AdStuInfo adStu) 
        ...{ 
            if (word == null) 
            ...{ 
                word = new WordApplication(); 
            } 
            object oMissing = System.Reflection.Missing.Value;   //這個(gè)東西找了好久,不像操作Excel,用Type.mising還不行. 
            object path1 = (object)path; 
            Document doc = null; 
            doc = word.Documents.OpenOld(ref path1, ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing, ref oMissing); 
            替換書(shū)簽#region 替換書(shū)簽 
                object markName = "報(bào)考單位"; 
                Bookmark bm = doc.Bookmarks.get_Item(ref markName); 
                bm.Range.Text = adStu.SiSch; 
                markName = "報(bào)考專業(yè)"; 
                bm = doc.Bookmarks.get_Item(ref markName); 
                bm.Range.Text = adStu.SiMa; 
                markName = "考生姓名1"; 
                bm = doc.Bookmarks.get_Item(ref markName); 
                bm.Range.Text = adStu.Name; 
                markName = "考生編號(hào)"; 
                bm = doc.Bookmarks.get_Item(ref markName); 
                bm.Range.Text = adStu.No; 
                markName = "調(diào)劑專業(yè)"; 
                bm = doc.Bookmarks.get_Item(ref markName); 
                bm.Range.Text = adStu.AdMa; 
                markName = "打印時(shí)間"; 
                bm = doc.Bookmarks.get_Item(ref markName); 
                bm.Range.Text = GetDate().ToString(); 
                markName = "考生姓名2"; 
                bm = doc.Bookmarks.get_Item(ref markName); 
                bm.Range.Text = adStu.Name; 
            #endregion 
                word.Visible = true; 
                doc.PrintPreview(); 
        } 
具體解釋:     首先有一個(gè)模板.doc文件,在該模板內(nèi)需要添加數(shù)據(jù)的地方設(shè)置成書(shū)簽,.NET程序所要的事情就是打開(kāi)該模板,用具體需要添加的值去替換先設(shè)定好的書(shū)簽,然后返回Word的打印預(yù)覽頁(yè)面,思路很簡(jiǎn)單~但是問(wèn)題也是有滴~~

這個(gè)程序是做打印我們學(xué)院研究生辦發(fā)復(fù)試生調(diào)卷函用的,但是表格是從學(xué)校研究生部那弄來(lái)的,主要還是在那邊蓋的章~所以就只能用那些表格來(lái)打,但是給的表格留的空實(shí)在太小,沒(méi)法用同樣的字體給打上去,怪就只能怪研究生部根本沒(méi)想到我們這會(huì)有這個(gè)高級(jí)的東西~~哈哈~估計(jì)一般都是手工填的~~~明天過(guò)去不知道具體要怎么弄,估計(jì)這東西在打印調(diào)卷函是發(fā)揮不出作用了~~~留著以后肯定有用!

4月16日修改:

       幾天前做的仔細(xì)想想還是有需要改進(jìn)的地方.我前面做的只是一個(gè)個(gè)文檔的填,一個(gè)個(gè)的打印,考慮資料上百個(gè)以后這樣做打印機(jī)的打印的效率不高,因?yàn)槊看沃唤o打印機(jī)發(fā)送一個(gè)打印任務(wù),它接受下一個(gè)任務(wù)是需要時(shí)間的,所以我的想法是把需要打印的文檔生成成一個(gè)文檔,這樣不但可以保存文檔,還可以只要向打印機(jī)發(fā)送一個(gè)任務(wù)就可以打印資料了,NB的打印機(jī)打印速度是很快的~~

       把具體的操作寫(xiě)下來(lái)吧~思路是打開(kāi)兩個(gè)word文檔(當(dāng)然,生成過(guò)程中全不可見(jiàn)),一個(gè)還是按照前面說(shuō)的替換書(shū)簽,但是不做打印處理,而是復(fù)制到另外一個(gè)文檔(該文檔存儲(chǔ)所有已經(jīng)生成好的表格,最后得到的就是這個(gè)word文檔,打印或者保存隨便他們).具體的代碼如下:

 

先在using里引如:
using Range = Microsoft.Office.Interop.Word.Range;

doc.Content.Copy();    //復(fù)制doc里的內(nèi)容,doc是每次做替換書(shū)簽的文檔.
object save = false;               
doc.Close(ref save, ref oMissing, ref oMissing);   //關(guān)閉doc.
Range range = printDoc.Content;   //全中printDoc里的全部?jī)?nèi)容,printDoc是目標(biāo)保存文檔.
range.Collapse(ref oMissing);   //確定粘貼的位置,其實(shí)這個(gè)地方我想放一個(gè)有效的參數(shù),把粘貼的位置設(shè)為文檔的末尾,而不是用默認(rèn)的文檔的最前面,但是幫助文檔是VB寫(xiě)的,傳了一個(gè)Direction:=wdCollapseEnd的東東,我弄半天沒(méi)弄出來(lái),虧我還是懂VB的~~傷心~以至于我都忘了傳個(gè)空值過(guò)去,卡了老半天!謝謝某人和我發(fā)了幾條短信,就一下把我打通了~
range.Paste();    //粘貼到目標(biāo)位置,一次填寫(xiě)就完成了.


        雖然是這樣,但是在生成目標(biāo)文檔的時(shí)候也是很耗資源的,我看了一下那程序竟然占了100多M的內(nèi)存!!而且~~而且~~我的機(jī)器在前兩次實(shí)驗(yàn)都沒(méi)頂住!死機(jī)了~~當(dāng)時(shí)真是在抓狂了~誰(shuí)知道后來(lái)幾次竟然無(wú)聲無(wú)息的成功!可是想想學(xué)院那機(jī)器能扛住么~~哎繼續(xù)優(yōu)化吧!這次把界面也改了一下,上面的生成在一的單獨(dú)線程里,以至于主界面不會(huì)像死了樣的,而且在主界面上還做了個(gè)顯示生成狀態(tài)的Lable,這東西還真管用~后面兩次的實(shí)驗(yàn),看著已生成數(shù)目超過(guò)前兩次死機(jī)的數(shù)目~~緊張的心情緩解了~再看著數(shù)目超過(guò)100~~高興了~最后慢慢接近完成數(shù)目時(shí)~~興奮得抓狂!!!!!哈~~

      哎~廢話多了點(diǎn)~有用的就那么幾行代碼~

AspNet技術(shù).net下實(shí)現(xiàn)Word動(dòng)態(tài)填加數(shù)據(jù)打印,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲精品美女久久777777 | 伦理片午夜在线视频 | 99热久久这里只精品国产WWW | 青柠电影在线看 | 妹妹我要操 | 伊人影院香蕉久在线26 | 国产做国产爱免费视频 | china野外18:19| 国产亚洲精品AV片在线观看播放 | 国产成人啪精品视频免费网 | 97精品国产自产在线观看永久 | 国产午夜精品一区二区理论影院 | 在线亚洲精品国产一区麻豆 | 少妇连续高潮抽搐痉挛昏厥 | 欧美在线看欧美视频免费 | 动漫美女和男人下载 | 综合一区无套内射中文字幕 | 日本高清天码一区在线播放 | 夜夜国产亚洲视频香蕉 | 美女撒尿无遮挡免费中国 | 十九岁在线观看免费完整版电影 | 色婷婷综合久久久中文字幕 | 亚洲高清国产拍精品动图 | 久久久综合中文字幕久久 | 三级黄.色| 在线播放毛片 | 精品无码国产污污污免费网站2 | 亚洲九九视频 | 亚洲另类国产综合在线 | 九九热视频免费 | 中文字幕一区二区三区在线播放 | 青青涩射射| 亚洲春色AV无码专区456 | 欧式午夜理伦三级在线观看 | 97免费视频在线观看 | 人妻少妇69式99偷拍 | 被窝国产理论一二三影院 | 欧美日韩精品一区二区三区四区 | 久久久久青草大香线综合精品 | 草699一码二码三码四码 | 亚洲高清国产拍精品动图 |