使用货币符号和千位分隔符解析浮点值
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 获取小数和千位分隔符