正则表达式获取字符串中的十进制值
由于我是C#开发人员,我也会接受C#答案。
可以说我有这个字符串:“R 560.00”
有一个Alpha字符和一个带小数值的空格。
我们也可以在字符串上有引号。
但我想要的是只获取字符串中的Decimal值。 应删除所有其他字符。
注意:String.Replace不能正常工作,这就是我转向Regex的原因。
这是我尝试过的:fields(amountIdx)将包含R560.00
Dim regex As New Regex("^[0-9]+(\.[0-9]{1,2})?$", RegexOptions.IgnoreCase) Dim amount As String = regex.Replace(fields(amountIdx), "^[0-9]+(\.[0-9]{1,2})?$")
但金额反映为R 560.00。 它不会删除其他字符。 我怎么能做到这一点?
你可以简单地使用
Regex.Replace("R500.12", "[^-?\d+\.]", ""))
例如: MsgBox(Regex.Replace("R500.12", "[^-?\d+\.]", ""))
它将返回500.12
这是一个LINQ hack,它取一个字符串中的第一个十进制y正数,其中“decimal-y”由一系列数字和点定义:
string s = "R 560.00"; string decimalyNumber = new String(s.SkipWhile(c => !Char.IsDigit(c) || c != '.') .TakeWhile(c => Char.IsDigit(c) || c == '.').ToArray());
它的工作原理是跳过字符直到找到一个数字/点,然后将所有内容都放在连续的数字和点序列中。 我认为性能不会那么热,但除非你在短时间内完成了数百万的这样做……
或者,您可以使用正则表达式并简单匹配[0-9]*(?:\.[0-9]+)?
,这是零个或多个数字,可选地后跟一个点和一个或多个数字(未捕获)。
试试这个
var resultArray = Regex.Split(input_string, @"[^0-9\.]+") .Where(c => c != "." && c.Trim() != "");
其中(c => …)是用于处理数组的每个元素的lambda,c是数组元素