微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

OpenOffice calc,宏可以自动更新单元格内容吗?

如何解决OpenOffice calc,宏可以自动更新单元格内容吗?

我使用了在网上论坛上找到的一个宏。

它检测指定单元格的背景颜色并返回该背景颜色的数值。问题是它只做一次。当我更改指示单元格的背景颜色时,数值不会更新。 要更新它,我必须在我调用宏的单元格中更改某些内容(例如,删除一个字符并重新键入它),然后按 Enter。然后更新数值。

有没有办法让它自动更新?或者,是否有一种更简单的方法来更新它(与所描述的删除和重新键入方法相比),最好是一种同时适用于多个单元格的方法

Villeroy 在 openoffice 论坛上的代码

Function CELL_BACKCOLOR(vSheet,lRowIndex&,iColIndex%)
'calls: getSheetCell
REM returns color code as number
Dim v
   v = getSheetCell(vSheet,iColIndex%)
   if vartype(v) = 9 then
      CELL_BACKCOLOR = v.CellBackColor
   else
      CELL_BACKCOLOR = v
   endif
End Function

Function getSheetCell(byVal vSheet,byVal lRowIndex&,byVal iColIndex%)
dim oSheet
'   print vartype(vsheet)
   oSheet = getSheet(vSheet)
   if varType(oSheet) <>9 then
      getSheetCell = NULL
   elseif (lRowIndex > oSheet.rows.count)OR(lRowIndex < 1) then
      getSheetCell = NULL
   elseif (iColIndex > oSheet.columns.count)OR(iColIndex < 1) then
      getSheetCell = NULL
   else
      getSheetCell = oSheet.getCellByPosition(iColIndex -1,lRowIndex -1)
   endif
End Function

解决方法

我不知道为什么“自动计算”设置在这种情况下不起作用(用 LibreOffice 7.0.2 测试)。无论如何,您可以手动更新单个单元格或多个单元格的宏输出:

  • 对于单个单元格,点击 F9
  • 对于多个单元格,选择它们并按 CTRL + SHIFT + F9

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。