问题:这是我想象中的正则表达式:
[0-9]{0,}\d\.[0-9]{0,}\d[i]|[0-9]{0,}\d[i]
只需要一个带有纯复杂部分的虚数。
当遇到我的解析器时,例如String im = "2i";
,它会转换为String z = "complex(0, 2)" //complex(re, im)
- 就像这样:
Matcher m = pattern.regex.matcher(exp); //String exp = "2i + 5"
if(m.find())
{
String key = m.group(); //String key = "2i"
int type = pattern.token;
if(type == COMPLEX)
{
key = key.replaceAll("i", ""); // key = "2"
exp = m.replaceFirst(""); // exp = "5"
exp = "complex(0," + key +")" + exp; //exp = "complex(0,2) + 5"
}
return exp;
}
我能用某种方式立刻用正则表达式做到这一点吗? E.g后跟字母“i”的任何十进制数转换为另一个字符串 - complex(0, number)
?
答案 0 :(得分:2)
以下是String#replaceAll
您可能想要尝试的示例:
// testing integers, comma-separated and floats
String test = "1 * 2i + 3.3i / 4.4 ^ 5,555i * 6,666 + 7,777.7i / 8,888.8";
System.out.println(
test
.replaceAll(
//| group 1: whole expression
//| | any 1+ digit
//| | | optional comma + digits
//| | | | optional dot + digits
//| | | | | final "i"
"(\\d+(,\\d+)?(\\.\\d+)?)i",
"complex(0, $1)"
)
);
<强>输出强>
1 * complex(0, 2) + complex(0, 3.3) / 4.4 ^ complex(0, 5,555) * 6,666 + complex(0, 7,777.7) / 8,888.8
注意强>
如果逗号部分会弄乱您的函数表达式(即complex(0, 1,2)
可能有问题),您可以:
"complex(0, \"$1\")"
等等。