我正在尝试使用正则表达式来解析小写的枚举,例如:
enum TransparencyState {
Gone, Translucent, Opaque
}
或
enum TransparencyState {
gone,
translucent,
opaque
}
但是,我能得到的最接近的是 (?:enum\s+[a-zA-Z0-9]+\s*\{|\G)\s+([a-zA-Z0-9_ ,\s]*)(?=[^{}]*\})
,但这并不完全有效。理想情况下,它只会匹配枚举列表中的小写常量,除了全部大写(基本上是如下常量形式)。
它不匹配:
enum TransparencyState {
GONE, TRANSLUCENT, OPAQUE_OR_DULL
}
如有任何帮助,我们将不胜感激。
最佳答案
试试这个正则表达式:
^enum[^{]*{\s*(?!\b[A-Z]+\b)(\w+(?:\s*,\s*(?!\b[A-Z]+\b)\w+)*)\s*}
在 JAVA 中,将每个 \
转义为另一个 \
解释:
^
- 断言行的开始enum[^{]*{\s*
- 匹配enum
后跟 0+ 次非{
的任何字符后跟{
后跟 0+ 个空格,尽可能多(?!\b[A-Z]+\b)
- 否定前瞻以确保下一个单词(枚举值)不只包含大写字母\w+
- 匹配出现 1 次以上的单词字母(仅当上述否定先行条件为真时)(?:\s*,\s*(?!\b[A-Z]+\b)\w+)*
- 匹配 0+ 个其他此类枚举值\s*}
- 匹配 0+ 个空格后跟}
关于java - 用于搜索小写枚举常量的正则表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54434100/