我有一个逗号分隔的字符串,我想把它转换成一个数组,这样我就可以遍历它。

有什么内置的功能吗?

例如,我有这个字符串

var str = "January,February,March,April,May,June,July,August,September,October,November,December";

现在我想用逗号将其拆分,然后将其存储在数组中。


当前回答

split()方法用于将字符串拆分为子字符串数组,并返回新数组。

var array = string.split(',');

其他回答

正如@oportocala所提到的,空字符串不会产生预期的空数组。

因此,要反击,请执行以下操作:

str
.split(',')
.map(entry => entry.trim())
.filter(entry => entry)

对于预期整数数组,请执行以下操作:

str
.split(',')
.map(entry => parseInt(entry))
.filter(entry => typeof entry ==='number')

已升级str.split(',')

简单的str.split(',')没有太多智能。以下是针对不同需求的一些升级。您可以根据自己的需要定制功能。

常量str=“a、b、c、d、e、f、g”常量num=“1、2、3、4、5、6、7.495”常量混合=“a,2,3,d,5,f,,7.495,g”console.log(str.split(','))//未修剪空格,包括空值//[“a”、“b”、“c”、“d”、“e”、“f”、“”、“g”]console.log(str.split(/[,]+/))//已修剪空格,跳过空值//[“a”、“b”、“c”、“d”、“e”、“f”、“g”]console.log(str.split(/\s*,\s*/))//已修剪空格,不跳过空值//[“a”、“b”、“c”、“d”、“e”、“f”、“”、“g”]console.log(num.split(',').map(数字))//数字,空值默认为零// [1, 2, 3, 4, 5, 6, 0, 7.495] console.log(num.split(/[,]+/).map(数字))//数字,跳过空值// [1, 2, 3, 4, 5, 6, 7.495]console.log(mix.split(/\s*,\s*/).map(x=>(x==='')?'':(是NaN(数字(x))?x:数字(x)))//混合值,包括空值//[“a”、2、3、“d”、5、“f”、“”、7.495、“g”]

使用JSON.parse

它可能感觉有点像黑客,但它很简单,并且被大多数Javascript引擎高度优化。

它还有其他一些优点,例如支持嵌套列表。但也有一些缺点,例如需要输入格式正确的JSON。

通过使用类似于上面使用string.split的string.replace,可以修复输入。在下面的前两个示例中,我自定义了如何处理空值:

常量num=“1、2、3、4、5、6、7.495”常量混合=“a,2,3,d,5,f,7.495,g”console.log(JSON.parse('['+num.replace(/,\s*,/,',0,')+']'))//数字,空值默认为零// [1, 2, 3, 4, 5, 6, 0, 7.495]console.log(JSON.parse('['+num.replace(/,\s*,/,',')+']'))//数字,跳过空值// [1, 2, 3, 4, 5, 6, 7.495]console.log(JSON.parse('['+mix.replace(/(^|,)\s*([^,]*[^0-9,][^,]*?)\s**(?=,|$)/g,'$1“$2”')+']'))//混合值,将在空值上出现ERROR//[“a”、2、3、“d”、5、“f”、“7.495”、“g”]

嗯,拆分是危险的,因为字符串总是可以包含逗号。注意以下事项:

var myArr = "a,b,c,d,e,f,g,','";
result = myArr.split(',');

那么你会怎么解释呢?你希望结果是什么?具有以下内容的数组:

['a', 'b', 'c', 'd', 'e', 'f', 'g', '\'', '\''] or
['a', 'b', 'c', 'd', 'e', 'f', 'g', ',']

即使你逃避逗号,你也会有问题。

我很快就把这件事弄混了:

(function($) {
    $.extend({
        splitAttrString: function(theStr) {
            var attrs = [];

            var RefString = function(s) {
                this.value = s;
            };
            RefString.prototype.toString = function() {
                return this.value;
            };
            RefString.prototype.charAt = String.prototype.charAt;
            var data = new RefString(theStr);

            var getBlock = function(endChr, restString) {
                var block = '';
                var currChr = '';
                while ((currChr != endChr) && (restString.value !== '')) {
                    if (/'|"/.test(currChr)) {
                        block = $.trim(block) + getBlock(currChr, restString);
                    }
                    else if (/\{/.test(currChr)) {
                        block = $.trim(block) + getBlock('}', restString);
                    }
                    else if (/\[/.test(currChr)) {
                        block = $.trim(block) + getBlock(']', restString);
                    }
                    else {
                        block += currChr;
                    }
                    currChr = restString.charAt(0);
                    restString.value = restString.value.slice(1);
                }
                return $.trim(block);
            };

            do {
                var attr = getBlock(',', data);
                attrs.push(attr);
            }
            while (data.value !== '')
                ;
            return attrs;
        }
    });
})(jQuery);

最简单的方法:

let myStr = '1, 2, 3, 4, 5, 7, 8';

const stringToArr = (myStr) => {
    return myStr.split(',').map(x => x.trim());
};

我有一个类似的问题,但更复杂的是,我需要将CSV文件转换为数组数组(每一行都是一个数组元素,其中包含一个以逗号分隔的项目数组)。

最简单的解决方案(我打赌更安全)是使用PapaParse,它有一个“无头”选项,可以将CSV文件转换为数组数组,而且它会自动检测到“,”作为分隔符。

另外,它是在Bower注册的,所以我只需要:

bower install papa-parse --save

然后在我的代码中使用它,如下所示:

var arrayOfArrays = Papa.parse(csvStringWithEnters), {header:false}).data;

我真的很喜欢。