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

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

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

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

沒想到昨天半天谷歌沒找到的解決方法今天早上換個(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)和本人猜測(cè),是在***生成的時(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)識(shí)文字始終是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)往下移動(dòng)幾行,就搞定了,根據(jù)數(shù)據(jù)多少,動(dòng)態(tài)復(fù)制表格。

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

  1. /**  
  2.      * 把選定的內(nèi)容或者插入點(diǎn)向下移動(dòng)  
  3.      *   
  4.      * @param pos  
  5.      *            移動(dòng)的距離  
  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è)表格,不論往下移動(dòng)幾個(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分頁(yè)

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對(duì)象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

2010-05-21 10:14:10

MySQL更改表結(jié)構(gòu)
點(diǎn)贊
收藏

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