偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

怎樣自動把報表插入到word文檔中

企業(yè)動態(tài)
在很多業(yè)務場景中需要在word文檔中嵌入報表。如果能把報表嵌入word文檔做成流水線式的自動化過程,那就是一件兩全其美,事半功倍的事情。

[[217561]]

在很多業(yè)務場景中需要在word文檔中嵌入報表。比如下圖這個報告:

 

這是一個某大學年度畢業(yè)生就業(yè)報告,其中表格和統(tǒng)計圖的數據來自數據庫,如果通過報表工具,制作這樣的表格和統(tǒng)計圖是輕而易舉的事情,但如果要把這些報表和統(tǒng)計圖做到word報告里就麻煩很多。以往有兩個辦法:一個是每次做好報表和統(tǒng)計圖之后,導出為word,再手工復制粘貼到word報告中;第二個是把整個報告都做成一個報表模板,然后再一起導出為word。 方法一,純手工操作效率低;方法二,報表工具排版能力有限,生成的word版面效果不夠***。

那么,還有什么好辦法呢?

通常這類報告都有規(guī)定的模板樣式,只是要定期替換里面的個別信息,比如上圖所示的文檔編號,報告時間,標題里的年度,圖片,每個章節(jié)下的報表和統(tǒng)計圖,這些信息是動態(tài)變化的,而其他文字描述部分以及整體樣式都是固定不變的。所以,如果能把報表嵌入word文檔做成流水線式的自動化過程,那就是一件兩全其美,事半功倍的事情。

潤乾報表就提供了把報表嵌入word的功能,實現步驟如下:

1、制作word模板,將需要插入內容的位置設置好書簽

 

比如我們開篇看到的大學畢業(yè)生就業(yè)報告,我們可以先做成如上圖所示的word模板,圖示綠色線框位置就是需要定期更新的部分,預先在這些位置插入書簽(比如書簽名為:編號,時間,logo,年度,報表,統(tǒng)計圖),以此標記要插入到word的內容對應插入到什么位置。

2、制作報表,這一步就不詳述了。

3、調用潤乾報表的raqsoft.report.view.oxml.word.DocxChanger里的方法,將圖片,文本,報表等內容插入到指定書簽位置,生成新的word報告。

 eg:

 

  1.  //設置報表授權文件 
  2.  
  3. File flic = new File(“c:/tmp/report5.lic”); 
  4.  
  5. FileInputStream lis = new FileInputStream(flic); 
  6.  
  7. Sequence.readLicense( Sequence.P_RPT, lis); 
  8.  
  9. File f = new File(“E:/test.docx”);               // 模板文件 
  10.  
  11. File of = new File(“D:/out.docx”);             // 輸出文件 
  12.  
  13.  … … 
  14.  
  15. FileOutputStream fos = new FileOutputStream(of); 
  16.  
  17.  DocxChanger dc = new DocxChanger(f, fos); //實例化DocxChanger 
  18.  
  19. //在書簽“編號”,“時間”,“年度”處插入文字 
  20.  
  21. dc.insertText(“編號“, “12345678”); 
  22.  
  23. dc.insertText(“時間“, “20170730”); 
  24.  
  25. dc.insertText(“年度“, “2017”); 
  26.  
  27.  //在書簽“logo”處插入圖片文件 
  28.  
  29. File f1 = new File(“d:/logo.png”); 
  30.  
  31. dc.insertImage(“logo”, f1); 
  32.  
  33. //在書簽“報表”,“統(tǒng)計圖”處插入報表和統(tǒng)計圖 
  34.  
  35. File f2 = new File(“d:/畢業(yè)去向.rpx”); 
  36.  
  37. FileInputStream fis =new FileInputStream(f2); 
  38.  
  39. IReport report = ReportUtils.read(fis); 
  40.  
  41.  fis.close(); 
  42.  
  43. Context context = new Context(); 
  44.  
  45. ……  
  46.  
  47. Engine engine = new Engine((ReportDefine) report, context); 
  48.  
  49. report = engine.calc(); 
  50.  
  51. dc.insertReport(“報表“, report);                 
  52.  
  53. File f3 = new File(“d:/留學.rpx”); 
  54.  
  55. FileInputStream fis2 =new FileInputStream(f3); 
  56.  
  57. IReport report2 = ReportUtils.read(fis2); 
  58.  
  59.  fis2.close(); 
  60.  
  61. Context context2 = new Context(); 
  62.  
  63. ……  
  64.  
  65. Engine engine2 = new Engine((ReportDefine) report2, context2); 
  66.  
  67. report2 = engine2.calc(); 
  68.  
  69. dc.insertReport(“統(tǒng)計圖“, report2);                          
  70.  
  71. //執(zhí)行所有修改動作,然后關閉輸出文件流 
  72.  
  73. dc.execute(); 
  74.  
  75. fos.close();  

至此,word報告就自動生成了,以后每次只要執(zhí)行一遍這段程序就行了,是不是方便了不少?

不過,這個辦法還有個缺點,當插入內容變化時,我們就需要修改java代碼,而改了代碼之后又得重編譯部署,難以做到熱切換。這個辦法還是不夠方便。

為此,潤乾報表還提供了外部配置的方法來實現word報表,可以預先編輯一個xml文件,在里面寫個需要替代的書簽等內容,然后程序會讀取這個配置文件生成相應的word文檔。

這樣,當插入內容變化的時候,只要修改xml配置信息即可,而不用修改代碼再編譯了。我們一起來看一下:

1、編輯配置文件xml

該文件中可配置多個書簽和插入對象,當對象來源于內存時,可配置成map,通過key從內存中取值,key值可以是IReport、byte[]、Image、String,值的類型程序會自動判斷。

 

  1. <?xml version=”1.0″ encoding=”UTF-8″ standalone=”yes”?> 
  2.  
  3. <!– file表示模板docx文件名,可配置絕對路徑或相對路徑(web端配置時相對于raqsoftConfig.xml中的reportFileHome) –> 
  4.  
  5. <docx file=”D:/test.doc”> 
  6.  
  7. <!– name表示docx書簽,為空則不會插入。 file表示圖片文件名,可配置絕對路徑或相對路徑(web端配置時相對于raqsoftConfig.xml中的reportFileHome) –> 
  8.  
  9. <bookmark name=”logo” type=”image” file=”D:/logo.png”/> 
  10.  
  11. <!– name表示docx書簽, text要插入的文本文字 –> 
  12.  
  13. <bookmark name=”編號” type=”text” text=”12345678 “/> 
  14.  
  15. <bookmark name=”時間” type=”text” text=”20170730“/> 
  16.  
  17. <bookmark name=”年度” type=”text” text=”2017 “/> 
  18.  
  19. <!– key表示給定map中的key(未填時跟name相同,對應的value只能是IReport、byte[]、Image、String) –> 
  20.  
  21. <bookmark name=”統(tǒng)計圖” type=”map” key=”f”/> 
  22.  
  23. <!– reportFile表示報表模板文件名,可配置絕對路徑或相對路徑(web端配置時相對于raqsoftConfig.xml中的reportFileHome)–> 
  24.  
  25. <bookmark name=”報表” type=”report” reportFile=”D:/畢業(yè)去向.rpx”> 
  26.  
  27. <!– value表示報表參數值(串) –> 
  28.  
  29.          <reportParam name=”arg1″ type=”value” value=”設定參數1″/> 
  30.  
  31. <!– type為map時會從內存中根據name讀取keykey未填寫時跟name相同,key=””時會取map中key為空的值–> 
  32.  
  33. <reportParam name=”arg2″ type=”map”/>        
  34.  
  35. </bookmark> 
  36.  
  37. </docx> 

注:在web應用中,如果web.xml里配置了reportServlet,那么程序會自動加載raqsoftconfig.xml,讀取該文件里配置的reportFileHome,數據源信息,授權文件等信息。

2、根據配置信息生成Word文檔

 

  1. try { 
  2.  
  3.  File of = new File(“D:/out.docx”);// 輸出文件 
  4.  
  5.  …… 
  6.  
  7. FileOutputStream fos = new FileOutputStream(of); 
  8.  
  9.  //加載xml,batch.xml內容如上一小節(jié)所示 
  10.  
  11.         String xmlConfig = DocxChanger.xmlFile2String(“D:/batch.xml”); 
  12.  
  13.          //當插入的對象來自內存,比如IReport對象 
  14.  
  15.          File f4 = new File(“d:/留學.rpx”); 
  16.  
  17.          FileInputStream fis = new FileInputStream(f4); 
  18.  
  19.          IReport report = ReportUtils.read(fis); 
  20.  
  21. fis.close(); 
  22.  
  23. Context context = new Context(); 
  24.  
  25. Engine engine = new Engine((ReportDefine) report, context); 
  26.  
  27. report = engine.calc(); 
  28.  
  29. //當對象來源于內存時,可配置成map 
  30.  
  31. HashMap map = new HashMap(); 
  32.  
  33.        map.put(“f”, report);   //設置xml中key為f的值 
  34.  
  35.        map.put(“arg2”, “2014-12-15 12:00:23”);//當插入對象來自內存,比如String,設置xml中key為arg2的值      
  36.  
  37. DocxChanger.insert(map, xmlConfig, fos); 
  38.  
  39.         fos.close(); 
  40.  
  41.        } catch (Throwable x) { 
  42.  
  43.       x.printStackTrace(); 
  44.  
  45.       } 

說了這么多,大家肯定會覺得理想很豐滿,現實很骨感,這個功能是很***,確實可以幫我解決這些個棘手的問題,但是都知道報表工具價格昂貴,再加上這樣小奢的功能,豈不是貴上加貴,為此特意買一套昂貴的報表工具,似乎就不劃算了,而開源報表里面又沒有這個功能。但是你不知道的是,現在報表工具已經低端化了,潤乾率先開始了2.8萬元/10套的低價報表了,恰巧這個功能里面有,恰巧你還看到了。

責任編輯:龐桂玉 來源: 潤乾
相關推薦

2024-07-15 15:05:20

Python數據驅動

2009-07-02 13:12:33

JSP打印報表

2024-11-14 13:19:21

Docker容器開發(fā)

2023-06-20 19:39:40

JavaScriptHTML

2022-09-29 10:06:56

SQLMySQL服務端

2018-08-02 21:28:00

軟件

2020-04-21 10:45:47

PythonWordExcel

2010-08-03 10:45:40

Sharepoint

2013-11-07 09:14:32

程序員項目經理

2011-04-02 12:55:20

SQL Server

2010-09-27 16:26:09

JVMarm

2009-09-01 13:51:51

C#創(chuàng)建Word文檔

2009-09-01 13:13:28

C#打開Word文檔

2024-09-03 08:26:59

Spring格式模板

2009-08-28 17:34:14

讀取word文檔

2009-09-01 13:25:25

C#Word文檔替換

2009-12-10 14:18:22

PHP導出Word文檔

2009-08-11 14:51:47

C#讀取Excel中數

2023-10-18 13:57:17

2011-03-10 10:20:37

應用程序Windows Azu
點贊
收藏

51CTO技術棧公眾號