2017-05-26 24 views
-4

我想用对话框构建按钮来匹配使用脚本的结果。例如,我将美国分为东,中,西。我有一个名为US 50州名和缩写的文本文件。当我键入“NY”或波士顿”,结果会显示‘东’我怎样才能在谷歌Spreadsheet.Thanks实现这一使用谷歌脚本搜索和匹配数组

+0

你好,我输入了这段代码,但没有地方可以搜索。我可以在哪里搜索?换句话说,我必须添加按钮来显示调用这个脚本吗? – HelloWorld

回答

1

这是脚本文件:

function findSection(state) 
{ 
    var state =(typeof(state) != 'undefined')?state: ''; 
    var found = "No Data Provided"; 
    if(state) 
    { 
    var ss = SpreadsheetApp.getActiveSpreadsheet(); 
    var sht = ss.getSheetByName('StateSearch'); 
    var rng = sht.getDataRange(); 
    var rngA = rng.getValues(); 
    found ='Not Found'; 
    for(var i=1;i<rngA.length;i++) 
    { 
     if((state==rngA[i][0]) || (state == rngA[i][1])) 
     { 
     found = rngA[i][2]; 
     break; 
     } 
    } 
    } 
    return found; 
} 

function searchSideBar() 
{ 
    var ui = HtmlService.createHtmlOutputFromFile('sectionSearchDialog').setTitle('State Search'); 
    SpreadsheetApp.getUi().showSidebar(ui); 
} 

这是HTML文件侧边栏:

<!DOCTYPE html> 
<html> 
    <head> 
    <base target="_top"> 
    </head> 
    <body> 
    State:<input type="text" id="txt1" size="30" value=""/><br /> 
    Section:<input type="text" id="txt2" size="30" value=""/><br /> 
    Search:<input type="button" value="Search" onClick="sectionSearch();" /> 
    <script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script> 
    <script> 
     console.log('here'); 
     function sectionSearch() 
     { 
     var v = $('#txt1').val(); 
     google.script.run 
      .withSuccessHandler(updateSection) 
      .findSection(v); 
     } 
     function updateSection(v) 
     { 
     $('#txt2').val(v); 
     } 
    </script> 
    </body> 
</html> 

这就是电子表格“StateSearch很像: 你可以在这里把状态数据和第三列,如果你愿意,你可以添加你的节名。添加城市是读者的特殊练习。祝你好运。

enter image description here

一个简单的方法来添加一些城市没有广告位置可能是这样:

同一侧边栏代码: 这个脚本文件:

function findSection(state) 
{ 
    var state =(typeof(state) != 'undefined')?state: ''; 
    var found = "No Data Provided"; 
    if(state) 
    { 
    var ss = SpreadsheetApp.getActiveSpreadsheet(); 
    var sht = ss.getSheetByName('StateSearch'); 
    var rng = sht.getDataRange(); 
    var rngA = rng.getValues(); 
    found ='Not Found'; 
    for(var i=1;i<rngA.length;i++) 
    { 
     if((state==rngA[i][0]) || (state == rngA[i][1]) || (isACity(state,rngA[i][3])>-1)) 
     { 
     found = rngA[i][2]; 
     break; 
     } 
    } 
    } 
    return found; 
} 

function searchSideBar() 
{ 
    var ui = HtmlService.createHtmlOutputFromFile('sectionSearchDialog').setTitle('State Search'); 
    SpreadsheetApp.getUi().showSidebar(ui); 
} 

function isACity(city,cities) 
{ 
    var city = (typeof(city) != 'undefined')?city:''; 
    var cities = (typeof(cities) != 'undefined')?cities:''; 
    var r = -1; 
    if(city && cities) 
    { 
    var citiesA = String(cities).split(','); 
    r = citiesA.indexOf(city); 
    } 
    return r; 
} 

电子表格如下: enter image description here

您必须运行侧栏co de加载它,或者你可以在onOpen()中做到这一点。希望这可以帮助。