質問
正規表現とGreasemonkeyを使用すると、次のような結果の配列が得られます。
choice1, choice2, choice3, choice3, choice1, etc..
私の質問は、選択肢をどのように集計するのですか?選択肢1が配列にある回数、選択肢2が配列にあるなどを知っています。選択肢の数や選択肢が正確にわからない場合は
最終的な目標は、各選択肢が複数のページにまたがる投票数を格納するGreasemonkeyスクリプトを作成することです(おそらく他のアイデアを受け入れますが、gm_setvalueを使用します)。
ありがとう!
解決
1つの手法は、選択肢を反復処理し、オブジェクトプロパティの一意の選択肢ごとに関連付けられたカウンターをインクリメントすることです。
例:
var choiceCounts = {};
for (var iLoop=0; iLoop < aChoices.length; iLoop++) {
var keyChoice = aChoices[iLoop];
if (!choiceCounts[keyChoice]) {
choiceCounts[keyChoice] = 1;
} else {
choiceCounts[keyChoice]++;
} //if
} //for
その後、プロパティが配列内に存在した回数に等しいプロパティを持つオブジェクトがあります。
他のヒント
探しているものが100%確実ではありませんが、これがそれだと思います。
// Original data
var choices = [
"choice 1",
"choice 1",
"choice 2",
"choice 3",
"choice 3",
"choice 3",
"choice 3",
"choice 3",
"choice 3",
"choice 4",
"choice 4",
"choice 4"];
//Create the results array
var result = new Object();
for (var choice in choices) {
if (result[choices[choice]] === undefined)
result[choices[choice]] = 1;
else
result[choices[choice]]++;
}
//Print result
var str = "";
for (var item in result)
str += item + ": " + result[item] + "<br />";
document.getElementById("resultDiv").innerHTML = str;
出力:
choice 1: 2
choice 2: 1
choice 3: 6
choice 4: 3
最初に配列をソート してから、1回スイープして発生をカウントできます(上記のRyanの提案と同様)。
所属していません StackOverflow