• 如何将微软 Office 宏转换为 ONLYOFFICE 宏


    想要将微软 Office VBA 宏转换为可在 ONLYOFFICE 中无缝使用的宏?嗯,虽然这种需求并没有直接的解决方案,不过我们也会在本文中介绍 VBA 宏的转换步骤——正好我们手上也有一个来自用户的实际案例可供参考。

    Transforming a Microsoft Office macro into an ONLYOFFICE macro

    VBA 宏

    以下是原始的 VBA 宏代码:

    1. Sub Button1_Click()
    2. Dim mycel As Range
    3. For Each mycel In Columns("D:D").SpecialCells(xlCellTypeConstants, 23)
    4. If mycel = [TODAY()] Then mycel.Offset(0, 1) = [This_value]
    5. Next
    6. End Sub

    宏代码会对 D 列进行扫描,查找值为常量“23”的单元格,同时检查各个单元格中的值是否等于标记为 [TODAY()] 的单元格的值。如果值匹配的话,则会对其右侧的单元格进行更新,更新的值为标记为 [This_value] 的单元格中的值。

    Transforming a Microsoft Office macro into an ONLYOFFICE macro

    构建 ONLYOFFICE 宏

    在将上述宏转换为与 ONLYOFFICE 兼容的 JavaScript 宏的过程中,我们需要使用 ONLYOFFICE API。 

    对于 ONLYOFFICE 宏,我们首先需要通过 Api.GetActiveSheet() 函数获取活动工作表。然后便是从单元格 A2 和 A4 中获取值。这两个单元格就是 VBA 宏中 [TODAY()] 与 [This_value] 标记分别对应的单元格:

    1. var sheet = Api.GetActiveSheet();
    2. var dateValue = sheet.GetRange("A2").GetValue();
    3. var updateValue = sheet.GetRange("A4").GetValue();

    下一步是使用 sheet.GetRange(“D1:D10”) 定义需要进行迭代的单元格范围。这里的代码即确定了本例中的 D 列作为迭代范围,实际使用时您可按照自己的特定需求对其进行调整:

    var dateRange = sheet.GetRange("D1:D10");
    

    我们需要使用 ForEach 函数来在已定义范围内的各单元格上迭代执行代码。对于每个单元格,我们都会使用 range.GetValue() 来获取其当前值,然后与单元格 A2 内的值进行对比。如果匹配的话,则会使用 range.GetRow() 获取当前单元格的行号,然后借助 sheet.GetRange(“E” + row) 获取 E 列中的相应单元格:

    1. dateRange.ForEach(function(range) {
    2.   var currentDate = range.GetValue();
    3.   // 检查当前日期是否与单元格 A2 中的值匹配
    4.   if (currentDate === dateValue) {
    5.     // 获取 E 列中的相应单元格
    6.     var row = range.GetRow();
    7.     var oRange = sheet.GetRange("E" + row);  }
    8. });

    最后,我们可通过 oRange.SetValue(updateValue) 使用单元格 A4 中的值来更新下一单元格的值(向右侧偏移一列):

    1.    // 更新下一单元格中的值
    2.     oRange.SetValue(updateValue);
    3.   }
    4. });

    完整的宏代码如下:

    1. (function()
    2. {
    3.     var sheet = Api.GetActiveSheet();
    4. var dateValue = sheet.GetRange("A2").GetValue();
    5. var updateValue = sheet.GetRange("A4").GetValue();
    6. var dateRange = sheet.GetRange("D1:D10");
    7. dateRange.ForEach(function(range) {
    8.   var currentDate = range.GetValue();
    9.   // 检查当前日期是否与单元格 A2 中的值匹配
    10.   if (currentDate === dateValue) {
    11.     // 获取 E 列中的相应单元格
    12.     var row = range.GetRow();
    13.     var oRange = sheet.GetRange("E" + row);
    14.    // 更新下一单元格中的值
    15.     oRange.SetValue(updateValue);
    16.   }
    17. });
    18. })();

    点击这里,观看视频,看看宏的效果如何!

    总结一下,首先,我们无法直接将 VBA 宏转换为可在 ONLYOFFICE 中使用的 JavaScript 宏。不过,在为 ONLYOFFICE 构建宏的过程中,您可使用现有的 VBA 宏代码作为参考,与此同时借助 ONLYOFFICE API 方法,加上一些必要的调整,这样就能实现类似的功能。

    虽然在这一过程中可能会需要进行一些代码重构工作,不过其完全是可行的。希望文本中简要介绍的内容能够帮助您成功打造出功能强大的 ONLYOFFICE 宏。拥抱广阔的可能性,尽享自定义的优势与乐趣。祝愿您的探索之旅一帆风顺!

    相关链接

    ​ONLYOFFICE 论坛​

    ​ONLYOFFICE API 文档​

    ​宏示例​

    ​GitHub 上的 ONLYOFFICE

  • 相关阅读:
    世界坐标系、相机坐标系和图像坐标系的转换【详解】
    【C++进阶】二叉搜索树
    <Redis开发与运维>一书阅读笔记记录
    关于蓝桥杯单片机组自学的经验分享
    Linux -- 进程间通信之匿名管道
    Arcmap操作系列:80平面转经纬度84
    2000-2020全要素生产率OP法+LP法+OLS和固定效应法三种方法合集含原始数据和计算过程Stata代码
    USB PD v1.0快速充电通信原理
    阿里P8架构师推荐的从Paxos到Zookeeper分布式一致性原理与实践
    华为手机日历的功能大全,赶快来试试
  • 原文地址:https://blog.csdn.net/m0_68274698/article/details/134398014