我现在知道如何从外部网页加载表格的列。
现在我想对此进行扩展,并且:
- 从多个页面获取表格数据(按玩家位置排名)。
- 将其合并到一个主表中。
这是脚本当前获取的 URL (http:...fantasysports.yahoo.com...pos=QB) 。列是团队名称和团队在各个职位上的排名。
我想让它遍历其他位置(即 WR、RB、TE)。这只需将 URL 的最后 2 个字母更改为其各自的值即可。然后我想将所有这些数据放在一个数组中,其中第一列是团队名称,第二列是 QB 位置的排名,第三列是 WR 位置的排名,依此类推。
我的计划是将 放在GM_xmlhttpRequest
一个for
循环中,迭代不同的位置名称。
我的代码能够为职位显示单独的表格,但由于某种原因它们不按顺序排列。
我遇到的另一个问题是变量范围。当前newStatTable
是在parseResponse
函数内部定义的,但我无法从函数外部访问它。我尝试将其删除var
以var newStatTable
使其成为全球性的,但它没有用。
这是我正在寻找的示例输出数组(注意:我只是随机选择了这些等级):
TeamName QB WR TE and so on...
--- -- -- --
Jacksonville Jaguars 1 6 28
Sanfrancisco 49ers 4 2 32
Seattle Seahawks 31 5 10
这是我的尝试。
// ==UserScript==
// @name _Grab stuff of a *static*, third-party web site.
// @include http://football.fantasysports.yahoo.com/*
// @include https://football.fantasysports.yahoo.com/*
// @require http://ajax.googleapis.com/ajax/libs/jquery/2.1.0/jquery.min.js
// @grant GM_xmlhttpRequest
// ==/UserScript==
pos = ["QB", "WR", "RB", "TE", "K", "DEF"];
for (x in pos) {
GM_xmlhttpRequest ( {
method: "GET",
url: "http://football.fantasysports.yahoo.com/f1/326198/pointsagainst?pos=" + pos[x],
onload: parseResponse,
onerror: function (e) { console.error ('**** error ', e); },
onabort: function (e) { console.error ('**** abort ', e); },
ontimeout: function (e) { console.error ('**** timeout ', e); }
} );
}
function parseResponse (response) {
var parser = new DOMParser ();
var ajaxDoc = parser.parseFromString (response.responseText, "text/html");
var statRows = ajaxDoc.querySelectorAll ("#statTable0 > tbody > tr");
var newStatTable = $(statRows).map ( function () {
var tblRow = $(this);
var teamRank = parseInt (tblRow.find (".rank-indicator").text().trim(), 10);
var teamName = tblRow.find ("td:eq(1)").text().trim().split(" vs")[0];
return [ [teamName, teamRank] ]; //Return Teamname, Rank #
} ).get ();
console.log (newStatTable);
}