0

我有一个正则表达式需要验证文本是否采用受支持的货币格式。

^(\$|€|Fr.|£|kr|R?)\s*((([1-9](,\d{3}){3})|([1-9]\d{0,2}(,\d{3}){0,2})|(\d{1,10}))(\.\d{1,2})?)\s*(\$|€|Fr.|£|kr|R?)$

我支持以下内容:

  1. US Dollar (10000.00 or 10,000.00 or $10,000.00)
  2. Euro (10000.00 or 10,000.00 or €10,000.00)
  3. Francs (10000.00 or 10'000.00 or Fr.10'000.00)
  4. Pounds (10000.00 or 10'000.00 or £10,000.00)
  5. Kroner (10000,00 or 10'000.00 or 10.000,00 kr)
  6. Rand (10000.00 or 10,000.00 or R10,000.00)

我更新了它以支持上述所有格式。

^(\$|€|Fr.|£|kr|R?)\s*(((([1-9](,\d{3}){3})|([1-9]\d{0,2}(,\d{3}){0,2})|(\d{1,10}))(\.\d{1,2})?)|((([1-9](.\d{3}){3})|([1-9]\d{0,2}(.\d{3}){0,2})|(\d{1,10}))(\,\d{1,2})?)|((([1-9]('\d{3}){3})|([1-9]\d{0,2}('\d{3}){0,2})|(\d{1,10}))(\.\d{1,2})?))\s*(\$|€|Fr.|£|kr|R?)$

看起来不错,但我不知道为什么当我有这些格式时它也接受小数点后 3 位。

100,000.012
200.000,002
100'000.001

我应该只接受 2 位小数。

4

1 回答 1

0

我认为您需要删除 ? 在 \d{1,2})?

于 2015-03-05T17:18:53.730 回答