如果我有一个类似的数组:
var myArray:Array = new Array("a","b","c","d","e","f","g","b");
如何搜索它以确定其中出现的值的次数以及位置?我发现下面的代码很接近,但它只返回第一次出现。
function findIndexInArray(value:Object, arr:Array):Number {
for (var i:uint=0; i < arr.length; i++) {
if (arr[i]==value) {
return i;
}
}
return NaN;
}
var myArray:Array = new Array("a","b","c","d","e","f","g","b");
trace(findIndexInArray("b", myArray));
// OUTPUT
// 1
答案 0 :(得分:1)
您可以考虑返回搜索词存在的指标数组。例如:
var list:Array = ['a', 'b', 'b', 'c', 'd', 'e', 'f'];
function find(obj:Object, list:Array):Array
{
var result:Array = [];
for(var i:int = 0; i < list.length; i++)
{
if(list[i] = obj)
{
result.push(i);
}
}
return result;
}
var search:Array = find('b', list);
trace('b is found: ' + search.length + ' times at indices: ' + search);
// -- 'b is found: 2 times at indices [1, 2]
通过这种方式,您可以通过检查返回数组的长度来查看搜索词的出现次数。
答案 1 :(得分:0)
您可以使用join
和regex
来计算
类似的东西:
// convert to one long string
var str:String = myArray.join("");
// regex find the letter and count result
var count:int = str.match(new RegExp(letter,"a")).length;
尚未对其进行测试,因此代码可能需要调整,但这应该比循环遍历数组更快。
更新
// convert to one long string
var str:String = myArray.join("");
var pos:Array = new Array();
var n:int = -1;
// loop through array and find all indexes
while ((n = str.indexOf(searchFor, n+1)) != -1) pos.push(n);
只是一个警告,如果数组中的任何字符串有多个字符
,这将会中断