名扬数据:JACOB的复制表格与添加空行

在网上复制粘贴代码习惯了,所以没有合适的方法的时候自己都懒得动脑子。


没想到昨天半天谷歌没找到的解决方法今天早上换个思路几分钟就搞定了。


jacob是一个操作文档的组件,这个就不赘述了,想知道的同学可以去百度和谷歌。


这是网上的jacob操作word的一个复制表格的方法


    /**  

         * 在当前文档指定的位置拷贝表格  

         *   

         * @param pos  

         *            当前文档指定的位置  

         * @param tableIndex  

         *            被拷贝的表格在word文档中所处的位置  

         */ 

        public void copyTable(String pos, int tableIndex) {  

            Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();  

            Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))  

                    .toDispatch();  

            Dispatch range = Dispatch.get(table, "Range").toDispatch();  

            Dispatch.call(range, "Copy");  

            if (this.find(pos)) {  

                Dispatch textRange = Dispatch.get(selection, "Range").toDispatch();  

                Dispatch.call(textRange, "Paste");  

            }  

        } 


可是如果是要复制多个表格,并且是在生成过程中复制的话就遇到难题了。


因为如果要使用上面这个方法的话,需要一个标签提供表格copy时的坐标。



    public void insertText(String newText) {    

                Dispatch.put(selection, "Text", newText);    

            }  


insertText这个方法,据实验和本人猜测,是在最后生成的时候才写入的。


而不是立即实现。


所以使用


    /**  

         * 从选定内容或插入点开始查找文本  

         *   

         * @param toFindText  

         *            要查找的文本  

         * @return boolean true-查找到并选中该文本,false-未查找到文本  

         */ 

        public boolean find(String toFindText) {  

            if (toFindText == null || toFindText.equals(""))  

                return false;  

            // 从selection所在位置开始查询  

            Dispatch find = word.call(selection, "Find").toDispatch();  

            // 设置要查找的内容  

            Dispatch.put(find, "Text", toFindText);  

            // 向前查找  

            Dispatch.put(find, "Forward", "True");  

            // 设置格式  

            Dispatch.put(find, "Format", "True");  

            // 大小写匹配  

            Dispatch.put(find, "MatchCase", "True");  

            // 全字匹配  

            Dispatch.put(find, "MatchWholeWord", "True");  

            // 查找并选中  

            return Dispatch.call(find, "Execute").getBoolean();  

        } 


find方法寻找刚才插入的标识文字始终是false,那么理所当然,


copyTable(String pos, int tableIndex)这个方法是无用的。


所以昨天纠结了一下午。


今天早上突然福临心至。把copy这个方法的代码实现看了下。


我擦,我突然发现,无须用什么标签来替换插入表格,直接寻找到光标插入点不就行了。


稍微修改了下,其实就是删除了几行代码,就变成以下代码


    /**  

         * 在当前插入点拷贝表格  

         *   

         * @param tableIndex  

         *            被拷贝的表格在word文档中所处的位置  

         */ 

        public void copyTable(int tableIndex) {  

            Dispatch tables = Dispatch.get(doc, "Tables").toDispatch();  

            Dispatch table = Dispatch.call(tables, "Item", new Variant(tableIndex))  

                    .toDispatch();  

            Dispatch range = Dispatch.get(table, "Range").toDispatch();  

            Dispatch.call(range, "Copy");  

            Dispatch.call(selection, "Paste");  

        } 


so,在插入上一个表格之后,再将光标往下移动几行,就搞定了,根据数据多少,动态复制表格。


往下移动光标的代码:


    /**  

         * 把选定的内容或者插入点向下移动  

         *   

         * @param pos  

         *            移动的距离  

         */ 

        public void moveDown(int pos) {  

            if (selection == null) {  

                selection = Dispatch.get(word, "Selection").toDispatch();  

            }  

            for (int i = 0; i < pos; i++)  

                Dispatch.call(selection, "MoveDown");  

        } 


这样,就ok了。


但是在生成三个以上表格时,却发现一个问题,那就是后面的表格紧接上一个表格,不论往下移动几个光标都木有用。


那么,要如何是好呢。这时候,一个极其有用的代码就出现了,那就是插入一个空行:


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


全部搞定。


这次的过程给了我一个个赤果果的教训,那就是不要太依赖谷歌与度娘。