我想拆分这个字符串:
从“任何网站”获取“某物”
排列。我已经这样做了:
var array = $(this).val().replace(/\s+/g, ' ').split(" ");
但我不想用引号(“”)分割单词。
是否可以以简单的方式完成?
我想拆分这个字符串:
从“任何网站”获取“某物”
排列。我已经这样做了:
var array = $(this).val().replace(/\s+/g, ' ').split(" ");
但我不想用引号(“”)分割单词。
是否可以以简单的方式完成?
一个解法 :
var str = 'get "something" from "any site"';
var tokens = [].concat.apply([], str.split('"').map(function(v,i){
return i%2 ? v : v.split(' ')
})).filter(Boolean);
结果 :
["get", "something", "from", "any site"]
可能做的更简单。这里的想法是使用"
第一次拆分的奇数结果进行拆分,然后按空间拆分。
如果你想保留引号,你可以使用
var tokens = [].concat.apply([], str.split('"').map(function(v,i){
return i%2 ? '"'+v+'"' : v.split(' ')
})).filter(Boolean);
结果 :
['get', '"something"', 'from', '"any site"']
("\[a-zA-Z\s\]+"|\[a-zA-Z\]+)/g
: 表达式的解释在链接中。
var re = /([a-zA-Z]+)|("[a-zA-Z\s]+"?)\s?/g;
var str = 'get "something" from "any site"';
var match = re.exec(str);
alert(match[1]); \\ this will give you the first matched group
\\ in this case it would be the word "get"
这是另一种方法(演示)
function extract(input) {
var elements = input.split(/([^\"]\S*|\".+?\")\s*/),
matches = [];
for(index in elements) {
if(elements[index].length > 0) {
if(elements[index].charAt(0) === '"') {
matches.push(elements[index].substring(1, elements[index].length-1));
} else {
matches.push(elements[index]);
}
}
}
return matches;
}
alert(extract('get "something" from "any site"'))
一个非常简单的答案:
'get "something" from "any site"'.split(/"/);
[“获取”、“某物”、“来自”、“任何站点”、“”]
:)