作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试为包含“dog”但不包含“cat”的句子创建规则。我希望该函数返回 FALSE,因为该字符串同时包含“dog”和“cat”。
使用否定:
grepl("cat.*[^dog]", "asdfasdfasdf cat adsfafds dog", perl=T)
使用否定前瞻:
grepl("cat.*(?!dog)", "asdfasdfasdf cat adsfafds dog", perl=T)
使用stringr包中的str_detect函数
require(stringr)
str_detect("asdfasdfasdf cat adsfafds dog", "cat.*(?!dog|$)")
所有这三个方法都返回 true。
最佳答案
您可以使用此正则表达式查找包含猫但不包含狗的字符串:
^((cat((?!dog).)*)|(((?!dog).)*?cat((?!dog).)*)+)$
它基于答案 here .它考虑到狗可以在猫之前或之后出现。
所有解决方案的问题是 cat.*
会找到 cat
然后 .*
会吃掉所有东西,包括 狗
s.
还有,你忘了处理狗先于猫的情况。
正如 Druzion 指出的那样,char 类不是可行的方法。
关于regex - 单词负前瞻的意外结果(R 正则表达式),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36870396/
我有一个看起来像这样的字符串: text = "9) 9 的文本\r\n10) 10 的文本\r\n11) 11 的文本\r\n12) ...\r\n123) 123 的文本" 我正在尝试将其拆分如下
下一代的 3D Tiles 前瞻 原文:Introducing 3D Tiles Next, Streaming Geospatial to the Metaverse 原文发布时间:2021年11月
我有一个使用正则表达式回顾的 string.replace() 函数。 myString.replace(/(?
我是一名优秀的程序员,十分优秀!