- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在寻找一个正则表达式来在 :
字符上拆分用户提供的字符串,但当用户转义冒号 \:
或者它是 url 的一部分时则不会,例如https://stackoverflow..
。在 javascript 中,大多数浏览器还不支持 lookbehinds。是否可以对后视部分应用其他方法?
在 Chrome 上的 clojure/Clojurescript 中(它确实支持 lookbehinds)这个正则表达式可以解决问题:
#"(?<!\):(?!//)"
但不是在 Safari 中(例如)。
最佳答案
主要问题是当前浏览器不支持查找和否定前缀 \
所需要的查找,因此我们不包含 \:
。
一个解决方法(不是很漂亮,但它有效)是首先用一些你知道不会自然出现在你的文本中的“符号”替换 \:
,做你的拆分,然后替换回来任何 \:
。
例如,如果您的字符串中有“::”,此方法将返回一个空元素“”:
let regex = /:(?!\/\/)/
//original string literal \: has to be expressed as \\:
let str = "http://example.com::hello:dolly:12\\:00\\:PM";
//substitute out any \:
str = str.replace(/\\:/g,"<colon>"); //http://example.com::hello:dolly:12<colon>00<colon>PM
//now we split 'normally' without lookbehind
let arr = str.split(regex); //[ 'http://example.com', '', 'hello', 'dolly', '12\\:00\\:PM' ]
//substitute back \:
arr = arr.map(element => element.replace(/<colon>/g, "\\:")); //[ 'http://example.com', '', 'hello', 'dolly', '12\\:00\\:PM' ]
console.log(arr);
如果您只是在非空元素之后,您可以对其执行arr.filter(Boolean)
,或者使用@Skeeve 的匹配解决方案,因为它更适合此目的。
关于javascript - Lookbehind 替代方案,同时具有 lookbehind 和 lookahead,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56412475/
我正在寻找一个正则表达式来在 : 字符上拆分用户提供的字符串,但当用户转义冒号 \: 或者它是 url 的一部分时则不会,例如https://stackoverflow..。在 javascript
我试图让正则表达式以负向后视的方式捕获一些数据,这样如果某个字符串在它前面,它就不会匹配。我知道有两种基本格式,但都不起作用。 我在搜索应用程序中执行此操作,无法使用 java 进行扩充,因此解决方案
我有这个目标: 给定字符串:"Part1-part2-part3-part4-part5" 在第二次出现“-”时拆分它, 所以我期待一个数组 [ "Part1-part2", "part3-part4
我正在为此寻找替代方案: (?x[1]); 编辑: 要使用您当前的规范从 str.123 中删除 3,请使用相同的捕获 方法:捕获您需要的内容并恢复使用替换模式中的 $n 反向引用在结果中捕获的文本,
我正在为此寻找替代方案: (?x[1]); 编辑: 要使用您当前的规范从 str.123 中删除 3,请使用相同的捕获 方法:捕获您需要的内容并恢复使用替换模式中的 $n 反向引用在结果中捕获的文本,
这个问题在这里已经有了答案: Javascript Regex Lookbehind Alternative (2 个答案) 关闭 4 年前。 我正在匹配下面描述的三种模式,它们都是独立的。按照超链
在令人敬畏的正则表达式模块 (https://pypi.python.org/pypi/regex) 的 pypi 页面中指出\G 可以“在负的可变长度后视中使用以限制后视的距离”。非常有趣,但该页面
我正在尝试使用 tidyr 中的 extract 函数进行一些模式匹配。我已经在正则表达式练习网站上测试了我的正则表达式,该模式似乎有效,而且我正在使用 lookbehind assertion。 我
我需要在我的语料库中搜索诸如game 或shame 之类的词,但我想指定搜索以排除三个字符串 a game/a shame or , A game/A shame and a/an/A/An WORD
我试图在公式中替换所有缺少前面零的 float 。例如: “4+.5”应该变成:“4+0.5” 现在我读到 JavaScript 不支持向后看,那么我该如何实现呢?当前面有数字时,以下代码也会替换:
Javascript 中的 lookbehind regexps 有几种(有时是棘手的)解决方案。但是,这是最简单的方法,如果我需要一个零宽度! 使用全局搜索查看表达式,这可能会重叠。例如。使用 /(
更新的问题 假设字符串 "?foo=bar&nonfoo=bar&foo=bar" ,在这种情况下我需要捕获: foo=bar foo=foo 我用 Perl 做的, see here . 但是Jav
我需要捕获以 # 开头的所有行JavaScript 中的字符。我尝试使用类似以下正则表达式的内容,但事实证明 JavaScript 不支持积极的后向断言 (?<=) . /(?<=\n)\#[^\n]
我想将某些文件类型(例如“.txt”)与不以特定子字符串结尾的非空根名称(例如“-bad”)匹配。有了负后视支持,解决方案很简单: /.(? ((regex.test(input) === expec
我在 .net 中有一个字符串。 Para 1Para 2Para 3Para 4 现在,我只想获取标签 p 内的文本(Para 1、Para 2、Para 3、Para4)。 我使用了以下正则表达式
我有一个包含多个关键字的字符串。我想将字符串拆分为这些关键字的列表(但保留关键字,因为它们确定了以下数据的含义) 以下面的字符串为例: test_string = "ªttypmp3pfilfDjTu
如何让lookbehind变得贪婪? 在这种情况下,我希望后向处理消耗 : if is 存在。 m = Regex.Match("From: John", @"(?i)(?<=from:)....")
我想捕捉不带空格的单词。 var paragraphy="Apple banana kişiler ki örnek foo."; var word="kişiler"; var regex = ne
我正在尝试匹配以 .xsd 结尾但不以 form.xsd 结尾的字符串列表,我使用以下正则表达式: ArrayList files = new ArrayList(); files.add("/aba
此问题特定于 Java 7/8。 使用量词的相当复杂的正则表达式在像这样的后向断言中是被禁止的: (?<=(a|b*)*)bc 因为它会导致运行时异常并显示如下消息: look-behind grou
我是一名优秀的程序员,十分优秀!