使用货币符号和千位分隔符解析浮点值

Posted

技术标签:

【中文标题】使用货币符号和千位分隔符解析浮点值【英文标题】:Parse a floating-point value with a currency symbol and a thousands separator 【发布时间】:2015-03-05 08:09:14 【问题描述】:

我有以下字符串值:

40,582.00 欧元

29,098.30 美元

我想将它们转换为十进制值。

我试过Decimal.Parse,但它不起作用。我的 vb.net 代码:

Decimal.Parse("EUR 40,582.00", NumberStyles.Currency)
Decimal.Parse("$29,098.30", NumberStyles.Currency)

将此字符串值转换为十进制值的正确方法是什么?

【问题讨论】:

为什么不首先解析字符串以删除任何不是数字或小数分隔符的字符,然后进行转换? 如何从字符串中删除所有字符? @yu_ominae - 这不是一个好习惯。大量的字符串解析和满足多种货币以及文化问题。 问题是我需要解析不同的货币。 @Ahmedilyas 我知道,但如果他的字符串不使用货币符号,我不明白这将如何工作。 【参考方案1】:

阅读:https://msdn.microsoft.com/en-us/library/dwhawy9k.aspx

The Currency ("C") Format Specifier.<br>
    123.456 ("C", en-US) -> $123.46<br>
    123.456 ("C", fr-FR) -> 123,46 €<br>

阅读:FormatCurrency 阅读:http://www.vb-helper.com/howto_net_format_currency.html

你必须通过 CurrencySymbol 使用 Case 或其他东西

NumberFormatInfo MyNFI = new NumberFormatInfo();
MyNFI.NegativeSign = "-";
MyNFI.CurrencyDecimalSeparator = ".";
MyNFI.CurrencyGroupSeparator = ",";
MyNFI.CurrencySymbol = "$";

decimal d = decimal.Parse("$29,098.30", NumberStyles.Currency, MyNFI);

【讨论】:

如果我有多个 CurrencySymbol 怎么办?

以上是关于使用货币符号和千位分隔符解析浮点值的主要内容,如果未能解决你的问题,请参考以下文章

使用美元符号和千位分隔符格式化引导表 [关闭]

Javascript 从 NumberFormat 获取小数和千位分隔符

使用数字和千位分隔符修复格式错误的字符串

如何获取 toLocaleString() 方法的小数和千位分隔符?

在文本框中添加小数点和千位分隔符

ActionScript 3 将数字格式化为字符串 - 使用小数和千位分隔符