-4
我想用对话框构建按钮来匹配使用脚本的结果。例如,我将美国分为东,中,西。我有一个名为US 50州名和缩写的文本文件。当我键入“NY”或波士顿”,结果会显示‘东’我怎样才能在谷歌Spreadsheet.Thanks实现这一使用谷歌脚本搜索和匹配数组
我想用对话框构建按钮来匹配使用脚本的结果。例如,我将美国分为东,中,西。我有一个名为US 50州名和缩写的文本文件。当我键入“NY”或波士顿”,结果会显示‘东’我怎样才能在谷歌Spreadsheet.Thanks实现这一使用谷歌脚本搜索和匹配数组
这是脚本文件:
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很像: 你可以在这里把状态数据和第三列,如果你愿意,你可以添加你的节名。添加城市是读者的特殊练习。祝你好运。
一个简单的方法来添加一些城市没有广告位置可能是这样:
同一侧边栏代码: 这个脚本文件:
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;
}
您必须运行侧栏co de加载它,或者你可以在onOpen()中做到这一点。希望这可以帮助。
你好,我输入了这段代码,但没有地方可以搜索。我可以在哪里搜索?换句话说,我必须添加按钮来显示调用这个脚本吗? – HelloWorld