将逗号分隔的字符串转换为数组

Bla*_*man 688 javascript string split

我有一个逗号分隔的字符串,我想转换成一个数组,所以我可以循环它.

有内置的东西吗?

例如,我有这个字符串

var str = "January,February,March,April,May,June,July,August,September,October,November,December";
Run Code Online (Sandbox Code Playgroud)

现在想用逗号分割它并存储在Array对象中

Mat*_*chu 1164

var array = string.split(',');
Run Code Online (Sandbox Code Playgroud)

MDN参考,主要有助于limit参数的可能意外行为.(提示:"a,b,c".split(",", 2)出来["a", "b"],不是["a", "b,c"].)

  • 如果你确定你在`array`中有元素,那么`split`会正常工作,如果你期望来自服务器/数据库的数据你会遇到麻烦,因为'''.split(',')`有一个` length === 1` IE:`''.split(',')=== ['']` (6认同)
  • 简短又甜蜜,很高兴看到JavaScript`string`具有Java`String`的丰富性. (2认同)

pop*_*pop 127

注意你是否瞄准整数,如1,2,3,4,5.如果您打算在拆分字符串后将数组的元素用作整数而不是字符串,请考虑将它们转换为字符串.

var str = "1,2,3,4,5,6";
var temp = new Array();
// this will return an array with strings "1", "2", etc.
temp = str.split(",");
Run Code Online (Sandbox Code Playgroud)

添加这样的循环

for (a in temp ) {
    temp[a] = parseInt(temp[a], 10); // Explicitly include base as per Álvaro's comment
}
Run Code Online (Sandbox Code Playgroud)

将返回一个包含整数而不是字符串的数组.

  • 请注意,除非您明确设置它,否则parseInt()会尝试猜测基数,这会在处理前导零("001,002,003 ..."`)时导致意外结果.将`parseInt('010')`与`parseInt('010',10)`进行比较. (45认同)
  • `map`函数可用于在一行中进行整数解析:`str.split(',').map(parseInt)` (5认同)
  • 如果可以的话,我会更多地支持阿尔瓦罗的评论.我前一段时间学到了这一课,从未忘记它. (3认同)
  • +1这个例子更清楚,证明字符串不是静态对象,实际上是字符串变量. (2认同)

Jus*_*tme 32

嗯拆分是危险的imho,因为字符串总是可以包含逗号,请注意以下内容:

var myArr = "a,b,c,d,e,f,g,','";
result = myArr.split(',');
Run Code Online (Sandbox Code Playgroud)

那你怎么会混淆呢?你想要的结果是什么?一个数组:

['a', 'b', 'c', 'd', 'e', 'f', 'g', '\'', '\''] or 
['a', 'b', 'c', 'd', 'e', 'f', 'g', ',']
Run Code Online (Sandbox Code Playgroud)

即使你逃脱逗号你也有问题.

快速摆弄这个:

(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);
Run Code Online (Sandbox Code Playgroud)

随意使用/编辑:)

  • 这也适用于数字,我们不必为它们运行单独的 parseInt 循环,如下面的另一个答案中所述。这是真正的深刻思考。非常感谢,我认为这是最好的答案! (2认同)

Jak*_*lde 26

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

var array = string.split(',');
Run Code Online (Sandbox Code Playgroud)


vas*_*vas 25

升级版str.split(',')

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

const str = "a, b,c,  d  ,e  ,f,,g"
const num = "1, 2,3,  4  ,5  ,6,,7.495"
const mix = "a, 2,3,  d  ,5  ,f,,7.495,g"

console.log(    str.split(',')
) // spaces NOT trimmed, empty values included
  // ["a", " b", "c", "  d  ", "e  ", "f", "", "g"] 

console.log(    str.split(/[ ,]+/)
) // spaces trimmed, empty values skipped
  // ["a", "b", "c", "d", "e", "f", "g"] 

console.log(    str.split(/\s*,\s*/)
) // spaces trimmed, empty values NOT skipped
  // ["a", "b", "c", "d", "e", "f", "", "g"]

console.log(    num.split(',').map(Number)
) // numbers, empty values default to zero
  // [1, 2, 3, 4, 5, 6, 0, 7.495] 

console.log(    num.split(/[ ,]+/).map(Number)
) // numbers, skips empty values
  // [1, 2, 3, 4, 5, 6, 7.495]

console.log(    mix.split(/\s*,\s*/)
                .map(x => (x === '') ? '' : (isNaN(Number(x)) ? x : Number(x)) )
) // mixed values, empty values included
  // ["a", 2, 3, "d", 5, "f", "", 7.495, "g"]
Run Code Online (Sandbox Code Playgroud)

使用JSON.parse

它可能感觉有点像 hack,但它很简单,并且大多数 Javascript 引擎都进行了高度优化。

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

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

const num = "1, 2,3,  4  ,5  ,6,,7.495"
const mix = "a, 2,3,  d  ,5  ,f,7.495,g"

console.log(    JSON.parse('['+num.replace(/,\s*,/,',0,')+']')
) // numbers, empty values default to zero
  // [1, 2, 3, 4, 5, 6, 0, 7.495]

console.log(    JSON.parse('['+num.replace(/,\s*,/,',')+']')
) // numbers, skips empty values
  // [1, 2, 3, 4, 5, 6, 7.495]

console.log(    JSON.parse('['+mix.replace(/(^|,)\s*([^,]*[^0-9, ][^,]*?)\s*(?=,|$)/g,'$1"$2"')+']') 
) // mixed values, will ERROR on empty values
  // ["a", 2, 3, "d", 5, "f", "7.495", "g"]  
Run Code Online (Sandbox Code Playgroud)


use*_*213 15

请注意以下内容:

 var a = "";
var x = new Array();
x = a.split(",");
alert(x.length);
Run Code Online (Sandbox Code Playgroud)

会警告1


BJ *_*tel 11

将逗号分隔后的字符串传递给此函数,它将返回数组,如果没有逗号分隔的字符串,则返回null.

 function SplitTheString(CommaSepStr) {
       var ResultArray = null; 

        if (CommaSepStr!= null) {
            var SplitChars = ',';
            if (CommaSepStr.indexOf(SplitChars) >= 0) {
                ResultArray = CommaSepStr.split(SplitChars);

            }
        }
       return ResultArray ;
    }
Run Code Online (Sandbox Code Playgroud)

  • 请解释*为什么此代码解决了所提出的问题,而不是仅发布一段代码.没有解释,这不是答案. (3认同)

Mub*_*han 9

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

let arr = str.split(',');
Run Code Online (Sandbox Code Playgroud)

它会导致:

["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"]
Run Code Online (Sandbox Code Playgroud)

如果您想将以下内容转换为:

["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"]
Run Code Online (Sandbox Code Playgroud)

这个:

"January,February,March,April,May,June,July,August,September,October,November,December";
Run Code Online (Sandbox Code Playgroud)

用:

str = arr.join(',')
Run Code Online (Sandbox Code Playgroud)


And*_* AR 7

返回功能

var array = (new Function("return [" + str+ "];")());
Run Code Online (Sandbox Code Playgroud)

它的接受字符串和对象串

var string = "0,1";

var objectstring = '{Name:"Tshirt", CatGroupName:"Clothes", Gender:"male-female"}, {Name:"Dress", CatGroupName:"Clothes", Gender:"female"}, {Name:"Belt", CatGroupName:"Leather", Gender:"child"}';

var stringArray = (new Function("return [" + string+ "];")());

var objectStringArray = (new Function("return [" + objectstring+ "];")());
Run Code Online (Sandbox Code Playgroud)

JSFiddle https://jsfiddle.net/7ne9L4Lj/1/

  • 文本字符串有错误-SyntaxError:意外的标识符编号字符串是可以的。例如。`var stringtext =“字符串,文本,I,是”; var stringtextArray =(new Function(“ return [” +字符串文本+“];”)());`结果是:SyntaxError:意外的标识符 (3认同)

Kab*_*bb5 6

我知道这个问题已经回答了很长时间,但是我认为我的贡献对其他研究此主题的人将是有益的...

这是一个将字符串转换为数组的函数,即使列表中只有一项(没有分隔符)也是如此:

function listToAray(fullString, separator) {
  var fullArray = [];

  if (fullString !== undefined) {
    if (fullString.indexOf(separator) == -1) {
      fullAray.push(fullString);
    } else {
      fullArray = fullString.split(separator);
    }
  }

  return fullArray;
}
Run Code Online (Sandbox Code Playgroud)

像这样使用它:

var myString = 'alpha,bravo,charlie,delta';
var myArray = listToArray(myString, ',');
myArray[2]; // charlie

var yourString = 'echo';
var yourArray = listToArray(yourString, ',');
yourArray[0]; // echo
Run Code Online (Sandbox Code Playgroud)

我创建此函数是因为split如果字符串中没有分隔符(仅一项),则会引发错误

  • 如果未找到分隔符,则不会引发任何错误:`'echo'.split(',')`返回`['echo']`,而`''.split(',')`返回`[''] `。如果当x不是字符串时(包括当x是_undefined_或_null_时)调用x.split(',')`,将会_出错_,因为其他类型没有`split`函数。 。 (3认同)

Die*_*mio 5

我遇到了类似的问题,但是由于我需要将csv转换为数组数组(每行是一个数组元素,内部具有一个由逗号分隔的项的数组),因此问题更加复杂。

最简单的解决方案(我敢打赌,更安全)是使用PapaParse(http://papaparse.com/),它具有“ no-header”选项,可将csv转换为数组数组,此外,它会自动检测到“ ”作为分隔符。

另外,它已在凉亭中注册,因此我只需要:

bower install papa-parse --save
Run Code Online (Sandbox Code Playgroud)

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

var arrayOfArrays = Papa.parse(csvStringWithEnters), {header:false}).data;
Run Code Online (Sandbox Code Playgroud)

我真的很喜欢它。