- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这是一个挑战!
正如标题所说,我想匹配 HTML 文档中除 <pre>、<code> 和 <textarea> 标签之外的所有内容(例如,您可以尝试以下文本)。
在我的情况下,目的是压缩 html,删除\n\t\r 和其他清理,除非像 textarea 那样严格要求。
当我在 PHP 中工作时,我也考虑过提取这些标签内容,在 PHP 中处理其余部分并将它们重新注入(inject)到 PHP 中。但我很好奇在正则表达式中做到这一点的方法!
我试过伟大的在线编辑器:http://regex101.com/表达式 ((?=.?)((?!<pre>).))
带有标志 'msg' 但不是我想要的。
任何帮助将非常感激!
Lorem ipsum dolor sat amet,consectetuer adipiscing elit,sed diam nonummy nibh euismod tincidunt ut laoreet dolore magna aliquam erat volutpat。 Ut wisi enim ad minim veniam, quis nostrud exerciation ullamcorper suscipit lobortis nisl ut aliquip ex ea commodo consequat。
Duis autem vel eum iriure dolor in hendrerit in vulputate velit esse Molestie consequat, vel illum dolore eu feugiat nulla facilisis at vero eros et accumsan et iusto odio dignissim qui blandit praesent praesent praesent de luptilitatum nulla facilisis at vero eros et accumsan et iusto odio dignissim Nam Liber tempor cum soluta nobis eleifend option congue nihil imperdiet doming id quod mazim placerat facer possim assum。
Typi non habent claritatem insitam; est usus legentis in iis qui facit eorum claritatem。
Mirum est notare quam littera gothica、quam nunc putamus parum claram、anteposuerit litterarum formas humanitatis per seacula quarta decima et quinta decima。Eodem modo typi,qui nunc nobis videntur parum clari, future 的未婚夫。
最佳答案
你可以使用这个:
$pattern = <<<'LOD'
~
# definitions :
(?(DEFINE) (?<tagBL> pre | code | textarea | style | script )
(?<tagContent> < (\g<tagBL>) \b .*? </ \g{-1} > )
(?<tags> < [^>]* > )
(?<cdata> <!\[CDATA .*? ]]> )
(?<exclusionList> \g<tagContent> | \g<cdata> | \g<tags>)
)
# pattern :
\g<exclusionList> (*SKIP) (*FAIL) | \s+
~xsi
LOD;
$html = preg_replace($pattern, ' ', $html);
preg_replace_callback()
来调整它。 .
</ \g{-1} >
至
(?: </ (?:\g{-1}| head | body | html) > | $)
例如在标签内容定义中,或者编写更高级的规则。
\t
或
\n
.如果您想要与双引号相同的行为,请使用 heredoc 语法。
/
来写他们的模式。分隔符。
/Gnagnagna/
,
/blablabla/ixUums
等。但是当他们编写一个包含大约一千或一百万个斜杠字符的模式时,他们更喜欢逐个转义千位斜杠,以选择另一个分隔符!使用 PHP,如果它不是字母数字字符,您可以选择所需的模式分隔符。我选择了
~
而不是
/
出于三个原因:
~
, 我不必转义斜杠,因为分隔符和文字字符没有歧义。 # comment
在行尾。
~([0-9]+)~
要匹配和捕获组 1 内的数字,您可以写
~(?<number>[0-9]+)~
.现在,使用这个命名的子模式,您可以使用
\g{number}
引用捕获的内容。或使用
\g<number>
到模式本身, 模式中的任何位置。例子:
~^(?<num>[0-9]+)(?<letter>[a-z]+)\g<num>\g<letter>$~
45ab67cd
~^(?<num>[0-9]+)(?<letter>[a-z]+)\g{num}\g<letter>$~
45ab45cd
但不是
45ab67cd
(?(DEFINE)...)
语法,您可以在主模式之外定义它们,因为您在这些括号之间编写的所有内容都不匹配。
~(?(DEFINE)(?<num>[0-9]+)(?<letter>[a-z]+))^\g<num>\g<letter>$~
45ab67cd
,因为都在
DEFINE
里面匹配部分将被忽略,但是:
~(?(DEFINE)(?<num>[0-9]+)(?<letter>[a-z]+))^\g<num>\g<letter>\g<num>\g<letter>$~
$str = 'cats meow because cats are bad.';
$pattern = '~^(\w+) \w+ \w+ \1 \w+ \w+\.$~';
var_dump(preg_match($pattern, $str));
true
因为模式匹配字符串。在图案中,
\1
指的是第一个捕获组的内容 (
cats
)。而不是写
\1
,您可以使用 oniguruma 语法和写作
\g{1}
也指第一个捕获组,它是相同的。
\g{-1}
(即我左边的第一组)
x # for verbose mode
i # make the pattern case insensitive (i.e. '~CaT~i' will match "cat")
s # (singleline mode): by default the . doesn't match newline, with the s modifier it does.
"aaaaab"
与
~a+ab~
正则表达式引擎,自
+
是一个贪婪的量词,将捕获所有
a
(五一),但之后它只留下一个
b
与子模式不匹配
ab
.正则表达式引擎的唯一方法是取回一个
a
,然后可以匹配
ab
.这是正则表达式引擎的默认行为。
(*SKIP)
和
(*FAIL)
(*FAIL)
是最容易的。子模式被迫立即失败。
(*SKIP)
:当子模式在此动词之后失败时,正则表达式引擎无权回溯此动词之前匹配的字符。并且此内容不能重用于另一个替代子模式。
关于php - html 文档中的正则表达式 : match all but every <(pre|code|textarea)>(. *?)</\\1>,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20421646/
我有一个加号/减号按钮,希望用户不能选择超过 20 个但不知道如何让它工作。我尝试使用 min="1"max="5 属性,但它们不起作用。这是我的代码和一个 fiddle 链接。https://jsf
我正在尝试复制顶部底部图,如示例 here但它没有正确渲染(紫色系列有 +ve 和 -ve 值,绿色为负值)留下杂乱的人工制品。我也在努力创建一个玩具示例来复制这个问题,所以我希望尽管我缺乏数据,但有
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎与 help center 中定义的范围内的编程无关。 . 已关闭 6 年前。 社区去年审查了是
这个问题在这里已经有了答案: Adding two positive integers gives negative answer.Why? (4 个答案) 关闭 5 年前。 我遇到了一个奇怪的问题
有谁知道如何将字符串值类型 -4,5 或 5,4 转换为 double -4.5 或 5.4? 最佳答案 只需使用 Double.parseDouble(Locale, String); 糟糕,我很困
我正在尝试根据 TextBlob 分类插入一个仅包含“正”或“负”字符串的新数据框列:对于我的 df 的第一行,结果是 ( pos , 0.75, 0.2499999999999997)我想要' 正
我对 VBA 非常陌生,无法理解如何在一个循环中完成 2 个任务。我非常感谢您的帮助。 我已经能够根据第 3 列中的数据更改第 2 列中的数值,但我不明白如何将负值的字体更改为红色。 表格的大小每月都
欢迎, 我正在使用 jquery 通过 POST 发送表单。 这就是我获得值(value)的方式。 var mytext = $("#textareaid").val(); var dataStrin
double d = 0; // random decimal value with it's integral part within the range of Int32 and always p
我有这个字符串: var a='abc123#xyz123'; 我想构建 2 个正则表达式替换函数: 1) 用 '*' 替换所有确实有 future '#'的字符(不包括'#') 所以结果应该是这样的
我正在使用 DialogFragment。当用户从 Gmail 平板电脑应用程序的屏幕与下面示例图片中的编辑文本进行交互时,我希望正面和负面按钮保持在键盘上方。 在我的尝试中不起作用,这是我的 Dia
从组装艺术一书中,我复制了这句话: In the two’s complement system, the H.O. bit of a number is a sign bit. If the H.O
是否有更好更优雅的方法来实现下面的简单代码(diffYear、A 和 B 是数字): diffYear = yearA - yearB; if (diffYear == 0) { A = B
我正在设计一种语言,并尝试确定 true 应该是 0x01 还是 0xFF。显然,所有非零值都将转换为 true,但我正在尝试确定确切的内部表示。 每种选择的优点和缺点是什么? 最佳答案 没关系,只要
在我的 dialogfragment 类的 OnCreateDialog 中,我正在这样做: AlertDialog.Builder builder = new AlertDialog.Builder
这个问题在这里已经有了答案: Resolving ambiguous overload on function pointer and std::function for a lambda usin
我偶然发现了一个奇怪的 NSDecimalNumber 行为:对于某些值,调用 integerValue、longValue、longLongValue 等,返回意想不到的值(value)。示例: l
这个问题在这里已经有了答案: Resolving ambiguous overload on function pointer and std::function for a lambda using
我有这个正则表达式来测试用户输入是否有效: value.length === 0 || value === '-' || (!isNaN(parseFloat(value)) && /^-?\d+\.
我想用高斯混合模型拟合数据集,数据集包含大约 120k 个样本,每个样本有大约 130 个维度。当我使用 matlab 执行此操作时,我运行脚本(簇号为 1000): gm = fitgmdist(d
我是一名优秀的程序员,十分优秀!