如何解决模式匹配使用正则表达式找出大于符号
| 我需要一个正则表达式,以便我搜索\“> \”大于。 例如 对于这个字符串,我将得到true-\“如果x> 2 \” 对于这个字符串,我会得到错误的\“<template>
\”
我已经试过了-[^<][a-zA-Z0-9_]+[a-zA-Z0-9_ ]*>
作为正则表达式
但问题是它找到了一个匹配的子字符串
例如,在<template>
中找到template>
并返回true。
谢谢。
编辑:
我正在使用此正则表达式[^<a-zA-Z0-9_][a-zA-Z0-9_]+[ ]*>
在整个firefox 1.0源代码中进行了尝试,它似乎运行良好。
解决方法
听起来您想匹配包含
>
但不包含<
的行。这种模式可以做到:
/^(?=.*>)[^<]+$/
但是,我很好奇您为什么要这样做。听起来可疑的是,您正在尝试使用正则表达式解析HTML,这通常是一个坏主意。
编辑:
现在,您正在尝试做的事情已经很清楚了,但是您应该意识到,这将限制正则表达式的功能。他们不能真正分辨出模板声明和带有尖括号的文本之间的区别,但是如果您知道模板声明都匹配非常特定的模式,则可以很好地捕获它们。
如果所有模板声明都遵循<[0-9]+template>
模式,则可以执行以下操作:
/^.*(?<!<\\d+template)>.*$/
如果您的模板没有遵循严格的约定,则需要一个真正的C ++解析器。正则表达式基本上不可能分辨出模板声明和以下内容之间的区别:
a=b<c>d;
...这是C ++中的有效代码(我相信可以翻译成a = (b < c) > d;
)。
, 正则表达式似乎是您要执行的工作的错误工具。您可能需要使用成熟的C ++解析器才能可靠地区分\“> \”大于运算符
来自\“> \”模板定界符,或\“> \”作为字符串文字或注释的一部分。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。