成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JACOB的復(fù)制表格與添加空行

開發(fā) 后端
在網(wǎng)上復(fù)制粘貼代碼習(xí)慣了,所以沒有合適的方法的時(shí)候自己都懶得動腦子。沒想到昨天半天谷歌沒找到的解決方法今天早上換個(gè)思路幾分鐘就搞定了。jacob是一個(gè)操作文檔的組件,這個(gè)就不贅述了,想知道的同學(xué)可以去百度和谷歌。

在網(wǎng)上復(fù)制粘貼代碼習(xí)慣了,所以沒有合適的方法的時(shí)候自己都懶得動腦子。

沒想到昨天半天谷歌沒找到的解決方法今天早上換個(gè)思路幾分鐘就搞定了。

jacob是一個(gè)操作文檔的組件,這個(gè)就不贅述了,想知道的同學(xué)可以去百度和谷歌。

這是網(wǎng)上的jacob操作word的一個(gè)復(fù)制表格的方法

  1. /**  
  2.      * 在當(dāng)前文檔指定的位置拷貝表格  
  3.      *   
  4.      * @param pos  
  5.      *            當(dāng)前文檔指定的位置  
  6.      * @param tableIndex  
  7.      *            被拷貝的表格在word文檔中所處的位置  
  8.      */ 
  9.     public void copyTable(String pos, int tableIndex) {  
  10.         Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();  
  11.         Dispatch table = Dispatch.call(tables, "Item"new Variant(tableIndex))  
  12.                 .toDispatch();  
  13.         Dispatch range = Dispatch.get(table, "Range").toDispatch();  
  14.         Dispatch.call(range, "Copy");  
  15.         if (this.find(pos)) {  
  16.             Dispatch textRange = Dispatch.get(selection, "Range").toDispatch();  
  17.             Dispatch.call(textRange, "Paste");  
  18.         }  
  19.     } 

可是如果是要復(fù)制多個(gè)表格,并且是在生成過程中復(fù)制的話就遇到難題了。

因?yàn)槿绻褂蒙厦孢@個(gè)方法的話,需要一個(gè)標(biāo)簽提供表格copy時(shí)的坐標(biāo)。

  1. public void insertText(String newText) {    
  2.             Dispatch.put(selection, "Text", newText);    
  3.         }  

insertText這個(gè)方法,據(jù)實(shí)驗(yàn)和本人猜測,是在***生成的時(shí)候才寫入的。

而不是立即實(shí)現(xiàn)。

所以使用

  1. /**  
  2.      * 從選定內(nèi)容或插入點(diǎn)開始查找文本  
  3.      *   
  4.      * @param toFindText  
  5.      *            要查找的文本  
  6.      * @return boolean true-查找到并選中該文本,false-未查找到文本  
  7.      */ 
  8.     public boolean find(String toFindText) {  
  9.         if (toFindText == null || toFindText.equals(""))  
  10.             return false;  
  11.         // 從selection所在位置開始查詢  
  12.         Dispatch find = word.call(selection, "Find").toDispatch();  
  13.         // 設(shè)置要查找的內(nèi)容  
  14.         Dispatch.put(find, "Text", toFindText);  
  15.         // 向前查找  
  16.         Dispatch.put(find, "Forward""True");  
  17.         // 設(shè)置格式  
  18.         Dispatch.put(find, "Format""True");  
  19.         // 大小寫匹配  
  20.         Dispatch.put(find, "MatchCase""True");  
  21.         // 全字匹配  
  22.         Dispatch.put(find, "MatchWholeWord""True");  
  23.         // 查找并選中  
  24.         return Dispatch.call(find, "Execute").getBoolean();  
  25.     } 

find方法尋找剛才插入的標(biāo)識文字始終是false,那么理所當(dāng)然,

copyTable(String pos, int tableIndex)這個(gè)方法是無用的。

所以昨天糾結(jié)了一下午。

今天早上突然福臨心至。把copy這個(gè)方法的代碼實(shí)現(xiàn)看了下。

我擦,我突然發(fā)現(xiàn),無須用什么標(biāo)簽來替換插入表格,直接尋找到光標(biāo)插入點(diǎn)不就行了。

稍微修改了下,其實(shí)就是刪除了幾行代碼,就變成以下代碼

  1. /**  
  2.      * 在當(dāng)前插入點(diǎn)拷貝表格  
  3.      *   
  4.      * @param tableIndex  
  5.      *            被拷貝的表格在word文檔中所處的位置  
  6.      */ 
  7.     public void copyTable(int tableIndex) {  
  8.         Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();  
  9.         Dispatch table = Dispatch.call(tables, "Item"new Variant(tableIndex))  
  10.                 .toDispatch();  
  11.         Dispatch range = Dispatch.get(table, "Range").toDispatch();  
  12.         Dispatch.call(range, "Copy");  
  13.         Dispatch.call(selection, "Paste");  
  14.     } 

so,在插入上一個(gè)表格之后,再將光標(biāo)往下移動幾行,就搞定了,根據(jù)數(shù)據(jù)多少,動態(tài)復(fù)制表格。

往下移動光標(biāo)的代碼:

  1. /**  
  2.      * 把選定的內(nèi)容或者插入點(diǎn)向下移動  
  3.      *   
  4.      * @param pos  
  5.      *            移動的距離  
  6.      */ 
  7.     public void moveDown(int pos) {  
  8.         if (selection == null) {  
  9.             selection = Dispatch.get(word, "Selection").toDispatch();  
  10.         }  
  11.         for (int i = 0; i < pos; i++)  
  12.             Dispatch.call(selection, "MoveDown");  
  13.     } 

這樣,就ok了。

但是在生成三個(gè)以上表格時(shí),卻發(fā)現(xiàn)一個(gè)問題,那就是后面的表格緊接上一個(gè)表格,不論往下移動幾個(gè)光標(biāo)都木有用。

那么,要如何是好呢。這時(shí)候,一個(gè)極其有用的代碼就出現(xiàn)了,那就是插入一個(gè)空行:

  1. Dispatch.call(selection, "TypeParagraph");//插入空行 

全部搞定。

 

這次的過程給了我一個(gè)個(gè)赤果果的教訓(xùn),那就是不要太依賴谷歌與度娘。

還是多看看源碼吧。

仰山之高,觀水之流…… 省我其心,撫爾之琴……

原文鏈接:http://www.cnblogs.com/kiok1210/archive/2012/05/26/2519223.html

責(zé)任編輯:林師授 來源: ~羽的博客
相關(guān)推薦

2010-04-06 14:26:41

Oracle復(fù)制表

2010-10-20 11:18:38

sql server復(fù)

2010-04-01 13:55:50

Oracle復(fù)制表

2011-01-26 08:59:11

jQueryjavascriptweb

2010-10-15 11:22:24

MySQL復(fù)制表結(jié)構(gòu)

2010-11-23 14:58:05

MySQL復(fù)制表數(shù)據(jù)

2009-12-09 10:51:18

ibmdwJava

2010-11-29 10:59:02

Sybase復(fù)制表結(jié)構(gòu)

2011-10-28 16:53:04

Jacob

2022-09-07 09:44:19

loading分頁

2019-11-24 19:17:06

MySQL異步復(fù)制全同步復(fù)制

2010-09-13 13:44:35

CSS表格CSS表單

2010-09-14 14:23:08

DIV+CSS

2010-07-07 17:33:41

SQL Server復(fù)

2023-06-16 07:48:51

DOM對象JS

2009-07-01 18:41:16

JSP編譯

2021-02-26 13:20:48

Shell空行Linux

2017-01-16 16:20:31

Windows 10右鍵菜單操作方法

2012-04-28 09:54:16

Java

2019-03-18 09:40:44

Linux命令編程語言
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 中文字幕 视频一区 | 一级大片网站 | 亚洲资源在线 | 天天看天天摸天天操 | 综合国产 | 久久久精品国产 | 久久亚洲精品国产精品紫薇 | 久久久久99| 欧美亚洲国产日韩 | 久久久高清 | 97超碰在线免费 | 日韩成人精品在线观看 | 成人一区二区三区视频 | 久久久久久久久久久福利观看 | 欧美日韩一区二区在线 | 成人高清视频在线观看 | 国产精品久久久久久久久久久免费看 | 超碰婷婷 | www.99精品 | 伊人热久久 | 香蕉久久久 | av资源中文在线 | 在线国产欧美 | 91精品久久久久久综合五月天 | 91高清免费 | 成年视频在线观看福利资源 | 精品真实国产乱文在线 | 成人在线精品 | 一级网站 | 7777精品伊人久久精品影视 | 福利网站在线观看 | 日韩精品一区二区三区在线播放 | 一区二区国产精品 | 国产精品亚洲精品日韩已方 | www.久| 麻豆av网| 一区二区三区中文字幕 | 天天操欧美 | 亚洲欧美在线观看视频 | 国产九九九九 | 亚洲精品一区二区网址 |