如何解决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 举报,一经查实,本站将立刻删除。