- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下运行良好的 pcre:
/[c,f]=("(?:[a-z A-Z 0-9]|-|_|\/)+\.(?:js|html)")/g
它根据输入生成所需的输出“foo.js”和“bar.html”
<script src="foo.js"...
<link rel="import" href="bar.html"...
问题是,OS X 版本的 grep 似乎没有像 -o
这样的选项来只打印捕获的组(根据另一个 SO 问题,这显然适用于 linux)。由于这将是 makefile 的一部分,我需要一个可以在任何 *nix 平台上运行的版本。
我尝试了 sed 但以下内容
s/[c,f]=("(?:[[:alphanum:]]|-|_|\/)+\.(?:js|html)")/\1/pg
抛出错误:“重复运算符的操作数无效”。我试过将其删除,不包括文件路径分隔符,我似乎无法破解它。将我的 pcre 转换成我几乎可以保证在符合 POSIX 标准(即使是非官方的)平台上的东西有什么帮助吗?
附言我知道我编写的正则表达式中固有的潜在故障模式,它只会用于具有相当特定格式的非常特定的文件。
最佳答案
POSIX 定义了两种风格的正则表达式:
BREs (Basic Regular Expressions) - 功能较少且需要 \
的旧版本-转义某些元字符,特别是 \(
, \)
和 \{
, \}
, 并且不支持重复符号 \+
(用 \{1,\}
模拟)和 \?
(用 \{0,1\}
模拟),不支持 \|
(交替;无法被模拟)。
EREs (Extended Regular Expressions) - 更现代的风格,但是缺少正则表达式内部的反向引用(这与捕获组不相同); 不支持词边界断言(例如\<
),不支持捕获组.
POSIX 还规定哪些实用程序支持哪种风格:哪些支持 BRE,哪些支持 ERE,哪些可选支持任一个,哪些 em>专门仅支持 BRE,或仅支持 ERE;特别是:
grep
默认使用 BRE,但可以使用 -E
启用 ERE sed
,遗憾的是,只有支持 BRE
sed
,但是,- 作为一个非标准扩展 - 确实 支持带有 -E
的 ERE开关(GNU sed
的更广为人知的别名是 -r
,但也支持 -E
)。awk
仅支持ERE此外,Linux 和 BSD/OSX 上的正则表达式库实现了对 POSIX ERE 语法的扩展 - 遗憾的是,这些扩展部分不兼容(例如单词边界断言的语法)。
至于您的特定正则表达式:
它使用非捕获组的语法,(?:...)
;但是,捕获组在 grep
的上下文中毫无意义,因为 grep
不提供替换功能。
如果我们删除这个方面,我们得到:
[c,f]=("([a-z A-Z 0-9]|-|_|\/)+\.(js|html)")
现在这是一个有效的 POSIX ERE(可以简化 - 参见 Benjamin W's helpful answer)。
然而,由于它是一个扩展 RE,使用sed
不是一个选项,如果你想保持严格的 POSIX 兼容。
因为 GNU 和 BSD/OSX sed
恰好实现-E
为了支持 ERE,您可以逃脱 sed
,如果这些平台是您唯一需要支持的平台 - 请参阅 anubhava's answer .
同样,GNU 和 BSD/OSX grep
碰巧实现了非标准 -o
选项(与您在问题中陈述的不同),因此,如果这些平台是您唯一需要支持的平台,您可以使用:
$ grep -Eo '[c,f]=("([a-z A-Z 0-9]|-|_|\/)+\.(js|html)")' file | cut -c 3-
c="foo.js"
f="bar.html"
(请注意,只有 GNU grep
支持 -P
以启用 PCRE,这只是解决方案(请注意 \K
,它会丢弃目前匹配的所有内容):
$ grep -Po '[c,f]=\K("([a-z A-Z 0-9]|-|_|\/)+\.(js|html)")' file
)
如果您真的想要严格符合 POSIX 标准的解决方案,您可以使用awk
:
$ awk -F\" '/[c,f]=("([a-z A-Z 0-9]|-|_|\/)+\.(js|html)")/ { print "\"" $2 "\"" }' file
关于regex - 将 PCRE 模式转换为 POSIX,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35686860/
运行 uwsgi 时,我收到以下消息: !!! no internal routing support, rebuild with pcre support !!! 我已经使用以下命令安装了 pcre
我对 PCRE(Perl 兼容正则表达式)的强大功能很感兴趣,并想知道它们是否有可能成为所有主要语言的事实上的方法(我对 Java 感兴趣)。如有必要,我准备使用图书馆。 我也无法在 SO 中找到描述
我正在尝试生成一些可以触发 snort 警报的跟踪以测试 snort 的性能。但是在一些规则中有一些pcre选项包含/R,我不明白。 例如,在一个snort规则pcre中有一个pcre选项:"/^(\
什么是 PCRE 兼容语法? C# PCRE 兼容吗?从维基百科我发现了这个: Perl Compatible Regular Expressions (PCRE) is a regular expr
我迷路了。我有 Linux CentOS 操作系统。我试图在 pcre 网站上下载的 pcre 包中找到 pcre.h。我也按照安装指南中的说明进行了配置,但没有运气。有帮助吗? 最佳答案 最新版本叫
我正在尝试使用以下命令配置和制作 pcre ./configure CC="gcc" CFLAGS="-maix64" CXX="gcc" CXXFLAGS="-maix64" LDFLAGS="-L
我想要一个 Perl 正则表达式来匹配 std::foo但不匹配 std::foo::bar .这是我到目前为止: /((?
我想这或多或少是一个由两部分组成的问题,但首先是基础知识:我正在编写一些 PHP 以使用 preg_match_all 来查找以 {} 结尾的字符串的变量。然后它遍历每个返回的字符串,用 MySQL
我有以下文字: aabbaa aa bbc aa bbg aa bbd aa 我想找到 以 bb 开头且 不在 aa 和 aa 之间 的单词,而不管使用 PCRE 的匹配单词之
PCRE 正则表达式 /..(?<=(.)\1)/无法编译:“后向断言中不允许子模式引用。”有趣的是,它似乎在前瞻中是可以接受的,例如 /(?=(.)\1)../ , 只是不在回顾中。 是否有技术原因
我想一步一步地理解以下模式。 /\p{L}/u /u 是一个修饰符(http://www.php.net/manual/en/reference.pcre.pattern.modifiers.php)
我有一个带有空值的文本源,我需要将它们与我的正则表达式模式一起拉出。正则表达式甚至可以匹配空字符吗? 当我的模式拒绝匹配时,我才意识到我有它们,当我将它粘贴到 Notepad++ 时,它显示了所有的空
我想演示我可以用制表符替换空格缩进,但只能替换每行的前导空格。 我想我可以通过可变宽度的后视来实现这一点。不幸的是,这在 PCRE 中是不允许的。 s/(?<=^|(?:[ ]{3})+)[ ]{3}
我必须在Python中基于PCRE解析一些字符串,而且我不知道该怎么做。 我想解析的字符串如下所示: match mysql m/^.\0\0\0\n(4\.[-.\w]+)\0...\0/s p/M
在 Notepad++ 6.5.1 中,我需要替换引号对中的某些模式。我想将替换保存为宏的一部分,因此所有替换都需要一步完成。 例如,在下面的字符串中,将引号对中的所有“a”字符替换为破折号,而引号对
使用 PCRE 库...想要查找最多包含已知空格数的单词字符串。 即标记之间有 5 个空白字符。 foo bar foo bar foo bar = 第一个 foo 和最后一个 bar 之间....有
我想演示我可以用制表符替换空格缩进,但只能替换每行的前导空格。 我想我可以通过可变宽度的后视来实现这一点。不幸的是,这在 PCRE 中是不允许的。 s/(?<=^|(?:[ ]{3})+)[ ]{3}
谁能举个例子例如对于这个字符串 wordride plain fire 用另一个字母替换空格 例如替换 第一个匹配空格前第三个字母的空格 例如我想在单词后替换字符用这个 (?:\G(?!^)|w
我很惊讶不容易找到类似问题的答案。我想匹配某些功能中的所有内容。这个想法是删除无用的功能。 foo(some (content)) --> some (content) 所以我试图匹配函数调用中可以包
我希望将大量模式与 Web 文档中的各种 HTML 元素、属性和文本相匹配。 例如,我可能对 的内容感兴趣元素并有一个这样的正则表达式: pcre *test_filter = pcre_compi
我是一名优秀的程序员,十分优秀!