首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用UNO将新行插入LibreOffice写入器表

使用UNO将新行插入LibreOffice写入器表
EN

Stack Overflow用户
提问于 2015-11-13 10:16:09
回答 1查看 1.2K关注 0票数 0

最近,我尝试编写一个小型java文件,该文件将把一行插入到.odt文档中已经存在的表中。表本身有4行和3列,但是如果要插入的内容大于4,我想实现一个检查,它将扩展该表。然而,每次我尝试获取表的行时,它都返回一个空指针。我对UNO并不那么熟悉,但在我阅读文档时,应该在这种情况下使用类XColumnsAndRowRange。我的代码如下:

代码语言:javascript
复制
XTextTablesSupplier xTablesSupplier = (XTextTablesSupplier) UnoRuntime.queryInterface(XTextTablesSupplier.class, xTextDocument);

    XNameAccess xNamedTables = xTablesSupplier.getTextTables();
    try {
        Object table = xNamedTables.getByName(tblName);
        XTextTable xTable = (XTextTable) UnoRuntime.queryInterface(XTextTable.class, table);
        XCellRange xCellRange = (XCellRange) UnoRuntime.queryInterface(XCellRange.class, table);
        if(flag){
            XColumnRowRange xCollumnAndRowRange =(XColumnRowRange) 
                    UnoRuntime.queryInterface(XColumnRowRange.class, xCellRange);
                XTableRows rows = xCollumnAndRowRange.getRows();

                 System.out.println("Testing if this works");
                rows.insertByIndex(4, size-4);
        }

我不确定我是否在这里遗漏了什么,或者我是否应该使用不同的函数。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-11-13 19:51:29

正如Lyrl所建议的那样,这是可行的:

代码语言:javascript
复制
XTableRows rows = xTable.getRows();

显然,XColumnRowRange只用于电子表格。

注意:使用Basic或Python您不会遇到这个问题,因为这些语言不需要queryInterface。守则只需:

代码语言:javascript
复制
table = tables.getByName(tblName)
rows = table.getRows()
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33690368

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档