RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 555947
Accepted
Maksym Katsovets
Maksym Katsovets
Asked:2020-08-16 20:07:06 +0000 UTC2020-08-16 20:07:06 +0000 UTC 2020-08-16 20:07:06 +0000 UTC

使用 Google 电子表格脚本合并相同的单元格

  • 772

我有一个包含列partner, id, email, status, type, group,的表格details。id列, email, status, type,中存在重复值group。

<!-- language: lang-none -->

| partner | id        | email               | status | type | group | details              |
|---------|-----------|---------------------|--------|------|-------|----------------------|
| YESTKBW | Wednesday | wednesday@gmail.com | YES    | 0    | 11    | kgplqolgbmdxenwpehyn |
| ZBSDCUY | Wednesday | wednesday@gmail.com | YES    | 0    | 11    | upujkpekm tmqfzpca   |
| RBGBHNK | Wednesday | wednesday@gmail.com | YES    | 0    | 11    | iky k gtlffdyukngwlo |
| UXJGHLW | Saturday  | saturday@gmail.com  | NO     | 0    | 11    | mjdmodggygxkydxifxny |
| UZHNECM | Friday    | friday@gmail.com    | YES    | 1    | 22    | wpboajbemueskbuyjqeg |
| XACTUOK | Tuesday   | tuesday@gmail.com   | NO     | 2    | 33    | rxnwkpmegng bobjdqlz |
| EIOBZXS | Tuesday   | tuesday@gmail.com   | NO     | 2    | 33    | rwqxxwoeanxqsbpbwx j |

id我正在尝试制作一个脚本,该脚本将合并列、、、、email中的单元格,status以获得相同的连续 id 值。不需要触及值。typegrouppartnerdetails

应该发生什么的例子

<!-- language: lang-none -->

| partner | id        | email               | status | type | group | details              |
|---------|-----------|---------------------|--------|------|-------|----------------------|
| YESTKBW | Wednesday | wednesday@gmail.com | YES    | 0    | 11    | kgplqolgbmdxenwpehyn |
| ZBSDCUY |           |                     |        |      |       | upujkpekm tmqfzpca   |
| RBGBHNK |           |                     |        |      |       | iky k gtlffdyukngwlo |
| UXJGHLW | Saturday  | saturday@gmail.com  | NO     | 0    | 11    | mjdmodggygxkydxifxny |
| UZHNECM | Friday    | friday@gmail.com    | YES    | 1    | 22    | wpboajbemueskbuyjqeg |
| XACTUOK | Tuesday   | tuesday@gmail.com   | NO     | 2    | 33    | rxnwkpmegng bobjdqlz |
| EIOBZXS |           |                     |        |      |       | rwqxxwoeanxqsbpbwx j |

我知道有必要使用mergeVertically()类方法Range,但我没有足够的经验来解决这个任务。

google-spreadsheet
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    contributorpw
    2020-08-21T23:07:24Z2020-08-21T23:07:24Z

    好的。这个问题与这个Hide rows with criteria on click没有明显不同。

    假设我们有一些合并单元格的方法:

    function verticallyMerger(sheet, blocks){
      /*
      {
      columns: [],
      rows: [[index, count],[index, count]]
      }
      */
      for (var i = 0; i < blocks.rows.length; i++){
        for (var j = 0; j < blocks.columns.length; j++){
          sheet.getRange(blocks.rows[i][0], blocks.columns[j], blocks.rows[i][1]).mergeVertically();
        }
      }
      return sheet;
    }
    

    一切都非常透明:

    • 通过设置排序
    • 依次申请

    它仍然是添加一个或多或少有用的自定义块构造函数。例如,

    function blockBilder(sheet, initialBlocks){
      var blocks = initialBlocks;
      blocks.rows = [];
      var values = sheet.getRange(1, blocks.mergerColumn, sheet.getLastRow()).getValues();
      var isNew = true;
      var prevVal;
      for(var i = 0; i < values.length; i++){
        if(prevVal === values[i][0]){
          if(isNew){
            blocks.rows.push([i , 2]);
            isNew = false;
          } else {
            blocks.rows[blocks.rows.length - 1][1]++;
          }
        } else {
          prevVal = values[i][0];
          isNew = true;
        }
      }
      return blocks;
    }
    

    当然,这里没有任何解释,并非一切都是显而易见的。initialBlocks必须代表这样的对象

    {
      mergerColumn : 2
    }
    

    mergerColumn- 将根据其得出关于需要合并的结论的列的编号

    现在可以运行了

    function run(){
      var sheet = SpreadsheetApp.getActiveSheet();
      var blocks = blockBilder(sheet, {mergerColumn : 2, columns: [2, 3, 4, 5, 6]});
      verticallyMerger(sheet, blocks);
    }
    

    又添加了一个blocks属性,这是必需的verticallyMerger- 这是columns. 它包含一个列出要合并的列的数组。

    在这里您可以获得工作示例和完整代码的副本。

    • 1

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    如何停止编写糟糕的代码?

    • 3 个回答
  • Marko Smith

    onCreateView 方法重构

    • 1 个回答
  • Marko Smith

    通用还是非通用

    • 2 个回答
  • Marko Smith

    如何访问 jQuery 中的列

    • 1 个回答
  • Marko Smith

    *.tga 文件的组重命名(3620 个)

    • 1 个回答
  • Marko Smith

    内存分配列表C#

    • 1 个回答
  • Marko Smith

    常规赛适度贪婪

    • 1 个回答
  • Marko Smith

    如何制作自己的自动完成/自动更正?

    • 1 个回答
  • Marko Smith

    选择斐波那契数列

    • 2 个回答
  • Marko Smith

    所有 API 版本中的通用权限代码

    • 2 个回答
  • Martin Hope
    jfs *(星号)和 ** 双星号在 Python 中是什么意思? 2020-11-23 05:07:40 +0000 UTC
  • Martin Hope
    hwak 哪个孩子调用了父母的静态方法?还是不可能完成的任务? 2020-11-18 16:30:55 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    user207618 Codegolf——组合选择算法的实现 2020-10-23 18:46:29 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    Arch ArrayList 与 LinkedList 的区别? 2020-09-20 02:42:49 +0000 UTC
  • Martin Hope
    iluxa1810 哪个更正确使用:if () 或 try-catch? 2020-08-23 18:56:13 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5