首先,这不是重复的:为什么通过 google api 进行的 google 搜索会返回不同的结果到网页中的搜索?也没有我能够找到的任何其他“谷歌搜索 API 返回意外结果”问题。
我正在编写一个使用 Google websearch API 的小型 javascript 程序。我正在为我的购买地点页面创建自定义链接,这些链接应该将用户引导到我们经销商网站上的正确页面,以购买他们在单击“购买地点”时最后一次查看的产品。我使用document.referrer的 javascript 方法,然后解析 URL 以确定用户上次访问我网站上的哪个页面。
然后我创建一个适当的查询字符串,将站点限制为特定经销商,告诉谷歌只返回一个结果然后运行查询。然后,我使用 URL 将该特定 div href 中的 HTML 重写为第一个(也是唯一一个)搜索结果。我本质上是在模仿谷歌曾经拥有的“我感觉很幸运”按钮的功能,但是以这样一种方式构建查询,以便我得到我正在寻找的结果。
好的,既然您知道我在做什么以及为什么要这样做,那么事情就变得奇怪了:我得到的大多数结果都很完美。他们返回第一个搜索结果。其中一些(并且总是相同的)返回第二个搜索结果。
这是您可以自己复制并粘贴到Code Playground中的代码,以查看我所指的问题:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8"/>
<title>Google AJAX Search API Sample</title>
<script src="http://www.google.com/jsapi?key=AIzaSyA5m1Nc8ws2BbmPRwKu5gFradvD_hgq6G0" type="text/javascript"></script>
<script type="text/javascript">
google.load('search', '1');
var SearchVariables = [
["alto","altomusic.com","http://www.earthworksaudio.com/wp-content/uploads/2012/03/altomusic-button.png","wp-image-6343"],
["acme","www.acmelectronics.com","http://www.earthworksaudio.com/wp-content/uploads/2012/03/acme-button.png","wp-image-6344"],
["bhphoto","www.bhphotovideo.com","http://www.earthworksaudio.com/wp-content/uploads/2012/03/bh-button3.png","wp-image-6345"],
["frontend","www.frontendaudio.com","http://www.earthworksaudio.com/wp-content/uploads/2012/03/frontend-button.png","wp-image-6346"],
["fullcompass","www.fullcompass.com","http://www.earthworksaudio.com/wp-content/uploads/2012/03/fullcompass-button3.png","wp-image-6347"],
["performance","www.performanceaudio.com","http://www.earthworksaudio.com/wp-content/uploads/2012/03/performance-audio-button.png","wp-image-6348"],
["proaudio","www.proaudiosuperstore.com","http://www.earthworksaudio.com/wp-content/uploads/2012/03/ProAudioSolutions-button.png","wp-image-6349"],
["rmc","www.rmcaudiodirect.com","http://www.earthworksaudio.com/wp-content/uploads/2012/03/rmc-button1.png","wp-image-6350"],
["sweetwater","www.sweetwater.com","http://www.earthworksaudio.com/wp-content/uploads/2012/03/sweetwater-button3.png","wp-image-6351"],
["vintageking","www.vintageking.com","http://www.earthworksaudio.com/wp-content/uploads/2012/03/vintageking-button3.png","wp-image-6352"]
];
var Search = new Array(SearchVariables.length);
function searchComplete() {
for(var i = 0; i < Search.length; i++){
if (Search[i].results && Search[i].results.length > 0) {
var contentDiv = document.getElementById(Search[i].ed[0]);
var curURL = Search[i].results[0].unescapedUrl;
var newImage = ' <a href="'+curURL+'"><img class="alignleft size-full '+Search[i].ed[2]+'" title="'+Search[i].ed[0]+'" src="'+Search[i].ed[1]+'" alt=" " width="235" height="94" /></a>';
contentDiv.innerHTML = newImage;
}
}
}
function parseURLString(inString)
{
var OutString = 'earthworks';
inString = inString.replace(/-/g,' ');
inString = inString.replace('zdt','');
var MicVsPre=['preamps','microphones'];
var idx = [];
for(var j=0;j<MicVsPre.length;j++)
{
if(inString.search(MicVsPre[j])>=0)
{
OutString = OutString+' '+MicVsPre[j];
for(var i=inString.length;i>0;i--)
{
if(inString[i]=='/')
{
idx.push(i);
}
}
OutString = OutString+' '+inString.substring(idx[0],idx[1]+1);
}
}
return OutString;
}
function OnLoad() {
var String_To_Parse = 'http://www.earthworksaudio.com/microphones/qtc-series-2/qtc40/';
var query = parseURLString(String_To_Parse);
var testloc = document.getElementById('vardiv');
testloc.innerHTML = query;
for(var i = 0; i < SearchVariables.length; i++)
{
Search[i] = new google.search.WebSearch();
Search[i].setNoHtmlGeneration();
Search[i].setResultSetSize(1);
Search[i].setUserDefinedLabel([SearchVariables[i][0],SearchVariables[i][2],SearchVariables[i][3]]);
Search[i].setSiteRestriction(SearchVariables[i][1]);
Search[i].setSearchCompleteCallback(this, searchComplete,null);
Search[i].execute(query);
}
}
google.setOnLoadCallback(OnLoad);
</script>
</head>
<body style="font-family: Arial;border: 0 none;">
<div id="vardiv">Testing</div>
<div id='acme'></div>
<div id='alto'></div>
<div id='bhphoto'></div>
<div id='fullcompass'></div>
<div id='frontend'></div>
<div id='performance'></div>
<div id='proaudio'></div>
<div id='rmc'></div>
<div id='sweetwater'></div>
<div id='vintageking'></div>
</body>
</html>
我已经包含了一个示例产品页面 URL,而不是实际使用document.referrer方法(因为显然你现在没有浏览我的网站)来演示发生了什么。我还在顶部创建了一个额外的 div 标签,它显示了正在执行的确切搜索。
如果您自己进行完全相同的搜索,请注意列表中的最后一个(复古王,或倒数第四个专业音频解决方案)如何拉下第二个搜索结果的 URL。然而,他们中的大多数正确地拉下了FIRST搜索结果(例如:sweetwater、b&h、full compass)。我在这些特定网站上进行的几乎每一次搜索都会发生这种情况。我知道这与我的浏览器以及我存储的设置无关,因为我已经在其他计算机上,在不同的浏览器等上尝试过这种隐身模式。有人知道这里发生了什么吗?为什么我总是不能从基于 Web 的 Google 搜索中获得第一个搜索结果作为返回的 URL?