如何使下面的正则表达式忽略大小写敏感性?它应该匹配所有正确的字符,但忽略它们是小写还是大写。
G[a-b].*
如何使下面的正则表达式忽略大小写敏感性?它应该匹配所有正确的字符,但忽略它们是小写还是大写。
G[a-b].*
当前回答
除了已经被接受的答案之外:
握把用法:
注意,对于greping,它只是添加了-i修饰符。示例:grep -rni regular_expression不规则地搜索“正则表达式”“r”,大小写“i”不敏感,在结果中显示行数“n”。
此外,这里还有一个验证正则表达式的好工具:https://regex101.com/
例:请看这幅图中的表达和解释。
引用:
手册页(Man grep) http://droptips.com/using-grep-and-ignoring-case-case-insensitive-grep
其他回答
i标志通常用于区分大小写。这里没有给出具体的语言,但可能是/G[ab]之类的。*/i or /(?i)G[ab].*/。
C#
using System.Text.RegularExpressions;
...
Regex.Match(
input: "Check This String",
pattern: "Regex Pattern",
options: RegexOptions.IgnoreCase)
options: RegexOptions。IgnoreCase
假设你想要整个正则表达式忽略大小写,你应该寻找i标志。几乎所有的正则表达式引擎都支持它:
/G[a-b].*/i
string.match("G[a-b].*", "i")
查看您的语言/平台/工具的文档,以查找匹配模式是如何指定的。
如果你只想让部分正则表达式不区分大小写(就像我最初的答案假设的那样),那么你有两个选择:
使用(?i)和[可选](?-i)模式修饰符: (?我)G (a - b)(? -我)。* 将所有的变量(即小写和大写)放在正则表达式中-如果不支持模式修饰符,则很有用: (gG) [a-bA-B]。*
最后一点:如果您处理的是ASCII之外的Unicode字符,请检查您的正则表达式引擎是否正确地支持它们。
正如我从这篇类似的文章中发现的那样(在AWK中ignorecase),在老版本的AWK上(比如在普通的Mac OS X上),你可能需要使用'tolower($0) ~ /pattern/'。
IGNORECASE或(?i)或/pattern/i将为每一行生成一个错误或返回true。
科特林:
"G[a-b].*".toRegex(RegexOption.IGNORE_CASE)