如何在 Basic 中使用 LibreOffice 功能?

Posted

技术标签:

【中文标题】如何在 Basic 中使用 LibreOffice 功能?【英文标题】:How to use LibreOffice functions into Basic? 【发布时间】:2015-05-13 13:33:33 【问题描述】:

我已经asked here 告知了这样做的好方法。

现在我正在尝试以下代码found here,并得到一些意外错误。

我想我没有以正确的方式使用它。有什么想法吗?

Sub Main 
    Dim aResult 
    Dim aFunc 
    Dim oRange 

    aFunc = GetProcessServiceManager().createInstance("com.sun.star.sheet.FunctionAccess") 

    aResult = aFunc.callFunction("SUM", Array(1, 2, 3))
    ' ---- Works OK
    Print aResult 

    aResult = aFunc.callFunction("MDETERM", Array(2, 5, 8)) 
    ' ---- IllegalArgumentException
    Print aResult 

    oRange = ThisComponent.sheets(0).getcellrangebyname("B4:B6") 
    aResult = aFunc.callFunction("ZTEST", Array(oRange, 2.5, 1.0)) 
    ' ---- IllegalArgumentException
    Print aResult 
End Sub

【问题讨论】:

你得到了哪些“意外错误”? 那些是 IllegalArgumentException,正如我在代码中提到的。它们涉及 cmets 上方的线。 【参考方案1】:

MDETERM 需要一个方阵。

ZTEST 仅在该范围内有值时才有效。

Sub Main 

    Dim oFunc as Object
    Dim vResult as Variant
    Dim oRange as Object
    Dim bDoZTEST as Boolean
    Dim aSubArray as Variant
    Dim vValue as Variant

    oFunc = GetProcessServiceManager().createInstance("com.sun.star.sheet.FunctionAccess") 

    vResult = oFunc.callFunction("SUM", Array(1, 2, 3))
    Print vResult 

    vResult = oFunc.callFunction("MDETERM", Array(Array(Array(2, 5, 8), Array(1, 4, 3), Array(9, 7, 6)))) 
    Print vResult 

    oRange = ThisComponent.sheets(0).getCellRangeByName("B4:B6") 
    bDoZTEST = true
    vResult = Empty
    for each aSubArray in oRange.DataArray
     for each vValue in aSubArray
      if not isNumeric(vValue) then bDoZTEST = false
     next
    next
    if bDoZTEST then vResult = oFunc.callFunction("ZTEST", Array(oRange, 2.5, 1.0)) 
    Print vResult 

End Sub

【讨论】:

以上是关于如何在 Basic 中使用 LibreOffice 功能?的主要内容,如果未能解决你的问题,请参考以下文章

在 Basic 中计算自己的对数(LibreOffice Calc Macro)

使用 BASIC 在 LibreOffice 中复制表格的最后一行

使用 LibreOffice Basic 迭代控件

如何在 libre office basic 中使用模块?

如何检索输入字段的值并使用它来修改 LibreOffice Basic 宏中的占位符?

我们如何在 Visual Basic 6 中导入 LibreOffice Writer 的监听器事件