在javascript中拆分字符串一次?

在javascript中拆分字符串一次?,javascript,split,Javascript,Split,如何仅拆分一次字符串,即使1 | Ceci n'est pas unie pipe:| Oui解析为:[“1”,“Ceci n'est pas unie pipe:| Oui”] 拆分中的限制似乎没有帮助…您可以使用: var splits = str.match(/([^|]*)\|(.*)/); splits.shift(); 正则表达式将字符串分成两个匹配组(括号内),第一个|前面的文本和后面的文本。然后,我们将返回结果以消除整个字符串匹配(拆分[0])。尝试以下操作: function

如何仅拆分一次字符串,即使
1 | Ceci n'est pas unie pipe:| Oui
解析为:
[“1”,“Ceci n'est pas unie pipe:| Oui”]

拆分中的限制似乎没有帮助…

您可以使用:

var splits = str.match(/([^|]*)\|(.*)/);
splits.shift();
正则表达式将字符串分成两个匹配组(括号内),第一个|前面的文本和后面的文本。然后,我们将返回结果以消除整个字符串匹配(
拆分[0]
)。

尝试以下操作:

function splitOnce(input, splitBy) {
    var fullSplit = input.split(splitBy);
    var retVal = [];
    retVal.push( fullSplit.shift() );
    retVal.push( fullSplit.join( splitBy ) );
    return retVal;
}

var whatever = splitOnce("1|Ceci n'est pas une pipe: | Oui", '|');

这不是一个很好的方法,但工作效率相当高:

var string = "1|Ceci n'est pas une pipe: | Oui";
var components = string.split('|');
alert([components.shift(), components.join('|')]​);​​​​​

使用javascript正则表达式功能并获取第一个捕获的表达式

RE可能看起来像
/^([^ |]*)\\\\\/


实际上,由于javascript正则表达式的贪婪性,如果验证字符串的格式是这样的,您只需要
/[^ |]*/

您需要使用
string.indexOf(“|”)
来获取第一次出现的“|”的索引。

var i = s.indexOf('|');
var splits = [s.slice(0,i), s.slice(i+1)];

与目前大多数答案一样邪恶:

var splits = str.split('|');
splits.splice(1, splits.length - 1, splits.slice(1).join('|'));

除了其他地方的商品之外,另一种简短的方法是使用
replace()

var str = "1|Ceci n'est pas une pipe: | Oui";
str.replace("|", "aUniquePhraseToSaySplitMe").split("aUniquePhraseToSaySplitMe");

正如@sreservoir在评论中指出的,唯一的短语必须是真正唯一的——它不能在您正在运行此拆分的源代码中,否则您会将字符串拆分为比您想要的更多的片段。正如他所说,如果您是针对用户输入(即,在浏览器中键入)运行此操作,则可能会出现无法打印的字符。

一行和imo,更简单:

var str = 'I | am super | cool | yea!';
str.split('|').slice(1).join('|');

如果字符串不包含分隔符,则返回“am super | cool | yes!”

。NickCraver的解决方案仍将返回两个元素的数组,第二个元素是空字符串。我更喜欢与split行为相匹配的行为。也就是说,如果输入字符串不包含分隔符,则只返回一个包含单个元素的数组

var splitOnce = function(str, delim) {
    var components = str.split(delim);
    var result = [components.shift()];
    if(components.length) {
        result.push(components.join(delim));
    }
    return result;
};

splitOnce("a b c d", " "); // ["a", "b c d"]
splitOnce("a", " "); // ["a"]

这个稍微长一点,但我认为它应该:

function split_limit(inString, separator, limit){
    var ary = inString.split(separator);
    var aryOut = ary.slice(0, limit - 1);
    if(ary[limit - 1]){
        aryOut.push(ary.slice(limit - 1).join(separator));
    }
    return aryOut;
}
console.log(split_limit("1|Ceci n'est pas une pipe: | Oui","|", 1));
console.log(split_limit("1|Ceci n'est pas une pipe: | Oui","|", 2));
console.log(split_limit("1|Ceci n'est pas une pipe: | Oui","|", 3));
console.log(split_limit("1|Ceci n'est pas une pipe: | Oui","|", 7));

零限制返回有趣的结果,但以效率的名义,我忽略了检查。如果需要,可以将其添加为函数的第一行:

if(limit < 1) return [];
if(limit<1)返回[];

ES6语法允许不同的方法:

function splitOnce(s, on) {
   [first, ...rest] = s.split(on)
   return [first, rest.length > 0? rest.join(on) : null]
}
它还通过返回null而不是更明确的空字符串来处理字符串没有
|
的可能性

splitOnce("1|Ceci n'est pas une pipe: | Oui", "|")
>>> ["1", "Ceci n'est pas une pipe: | Oui"]

splitOnce("Celui-ci n'a pas de pipe symbol!", "|")
>>> ["Celui-ci n'a pas de pipe symbol!", null]
管道?这是空的

我添加此回复主要是为了在管道符号上使用双关语,同时也是为了炫耀es6语法-令人惊讶的是,有多少人仍然不使用它…

如果你想使用“管道”,那么
reduce
是你的朋友

const separator='|'
jsonNode.split(分隔符)
.减少((以前、当前、索引)=>
{
如果(索引<2)上一次推送(当前)
else-previous[1]+=`${separator}${current}`
返回上一个
}, [])
.map((项:字符串)=>(项.trim())
.filter((项目:字符串)=>(项目!='')
更有效的方法:

const str=“1 | Ceci n'est pas une pipe:| Oui”
const[head]=str.split(“|”,1);
常量结果=[head,str.substr(head.length+1)]

控制台日志(结果)正确地说,应该在开始时锚定。但是javascript正则表达式似乎很贪婪。只有当“unique”短语不可计算时,这才有效。如果从文本文件读取,这是不可能的。如果从浏览器读取,则任何不可打印的控制字符(如果可能)都可以。tab也能创造奇迹。无论如何,“aUniquePhraseToSaySplitMe”几乎肯定是输入的一部分,因此是危险的。当然,您是正确的。我的例子只是一个简单解释正在做什么的例子。我将把你的观点纳入答案本身。谢谢如果你用str表示你的独特短语,你知道它不可能再出现在那里了!:我认为这实际上比正则表达式好。选择正确,谢谢!为了澄清这一点,他将其拆分为N个部分,然后将第一个部分弹出到一个列表中,并将其余部分加入到同一个列表中。如果您想从字符串中获得k个标记,而不是1个,请执行与上述相同的操作,只需使用components.splice(0,k)而不是components.shift()。对于那些想知道如何使用2个或更多卡盘的人,您可以在循环中使用shift或:
组件。拼接(0,2)。切片(0,2)
不像Nick的那样“有趣”,但可能效率更高。另请注意,
+1
如果不止一个字符,实际上应该是分隔符字符串的长度。为什么这个解决方案没有那么“有趣”?对于那些想知道,要使用2个或更多块来实现这一点的人,可以在循环中使用indexOf或:
var i=s.split(“|”,2).join(“|”).length//第二个指数
var splits=[s.slice(0,i).split(“|”),s.slice(i+1)]当IndexOf返回-1(例如,如果var s='string',它将返回['strin','string']),这与split不同。你必须写一个条件。这不是要求的,他们也在寻找缺少的第一部分。