7

我有一个谷歌电子表格。在某些单元格中,它有多个名称(字符串),我想将它们与各个超链接相关联。

例如,如果我有一个像“Charles Darwin”这样的单元格,我很容易通过执行类似的操作从这个名称创建一个超链接 =Hyperlink(VLOOKUP("Charles Darwin", People!$A$1:$B$738, 2, false), "Charles Darwin") (请注意,我有一个“人物”表,我可以从中获取超链接)

但是,如果我碰巧在该单元格中有多个条目,请说“;” 或换行符分隔,例如“查尔斯达尔文;乔治华盛顿”,我不能这样做。我想让用户能够单击单元格,将单元格的内容(作为参数)发送到某种脚本,并让该脚本在我的“人物”表中找到超链接字符串,然后在该单元格旁边向用户显示一个小“弹出窗口”,可以单击所需的超链接。

我试图在这个网站上找到类似的东西,但似乎没有类似的东西出现。是否有人可以为我提供一两个链接(或基本示例代码),我可以开始尝试解决这个问题?(我假设这是可能的)。

4

1 回答 1

4

在同一个单元格上不可能有两个超链接。

可以将脚本写入 Google 电子表格,但我不确定它是否适合您的用例。我看到的解决方案是这样的:

  • 用户单击所需的单元格,将其选中。
  • 然后他点击自定义菜单并在那里选择一个条目,例如显示链接
  • 将显示一个带有链接的弹出窗口(不是在单元格之外,而是在屏幕中央)。

你觉得这样好吗?代码看起来像这样(打开菜单工具 > 脚本编辑器)

function onOpen() {
  SpreadsheetApp.getActive().
    addMenu("Test", [{name: 'Show Links', functionName:'showLinks'}]);
}

function showLinks() {
  var values = SpreadsheetApp.getActiveRange().getValue().split(';');

  var app = UiApp.createApplication().setTitle('Links'); 
  var grid = app.createGrid(values.length, 2);

  for( var i = 0; i < values.length; ++i ) {
    var url = findLink(values[i]);
    grid.setWidget(
      i, 0, app.createLabel(values[i])).setWidget(
      i, 1, url ? app.createAnchor(url, url) : app.createLabel('Not Found'));
  }

  app.add(grid);
  SpreadsheetApp.getActive().show(app);
}

var mapName2Url = null;
function findLink(name) {
  if( mapName2Url == null ) { //lazy load
    mapName2Url = {};
    var data = SpreadsheetApp.getActive().getSheetByName('People').getDataRange().getValues();
    for( var i = 1; i < data.length; ++i ) //skipping the header
      mapName2Url[data[i][0]] = data[i][1];
  }
  return mapName2Url[name];
}

将其粘贴到脚本编辑器后,运行两次 onOpen 函数以对其进行授权并为您创建菜单。下次打开电子表格时,应该会自动创建菜单。

顺便说一句,我没有测试过这段代码,所以它可能包含愚蠢的错误。

于 2012-05-23T12:20:35.420 回答