将整数转换为货币

本文关键字:货币 转换 整数 | 更新日期: 2023-09-27 18:20:45

我们有一个以基础货币存储数字(货币)的数据库,因此21.30英镑将作为2130英镑存储在数据库中。我该如何将该数字转换为适用于所有文化的正确格式的货币?

2130->21.30英镑
2130->21.30美元
etc

将整数转换为货币

int valueFromDb = 2130;
decimal result = valueFromDb / 100m;
string formatted = result.ToString("c");

可以快速扩展方法化:

public static class CurrencyExtensions
{
    public static string AsCurrency(this int value)
    {
        return value.AsCurrency(CultureInfo.CurrentCulture);
    }
    public static string AsCurrency(this int value, CultureInfo culture)
    {
        decimal result = value / 100m;
        return result.ToString("c", culture);
    }
}

这样你就可以成为DRYier:

int valueFromDb = 2130;
string formatted = valueFromDb.AsCurrency();
string asLocalCurrency(int intMoney)
{
  return (num / 100m).ToString("c"); //e.g. 12345 becomes €123.45 for me
}
string asSomeLocalCurrency(int intMoney, CultureInfo cInfo)
{
  return (num / 100m).ToString("c", cInfo); // e.g. 12345 with InvariantCulture is ¤123.45
}

然而。这意味着123.45英镑变成了123.45美元或123.45欧元,这显然是不正确的。

还有一个问题是,比索/美元符号$可以用来表示NIO、AUD、CAD、TOP、USD、HKD等等。它并不是唯一一个在多个地方使用的符号。如果你正在记录旧的付款,即使是用于IEP和ITL(不再使用)的英镑也可能成为一个问题。

事实上,你将这些值存储为主单位百分比的整数,这并不适用于所有货币。

货币价值只有在隐含或显性货币的情况下才有意义。在这里,你选择了一个没有的,或者用显式替换隐含的,或者你依赖于一个很大的重写逻辑来保持正确。

最后一项可以奏效,但令人担忧。另外两个完全错了。

最后,文化充其量只能告诉你人们最熟悉的货币,但不能告诉你他们会一直使用什么。我经常使用kroner和øre,但在使用它们时,我仍然使用Hiberno英语。

我建议将ISO 4217代码与货币一起存储。把它也写在最终发票上是个好主意。符号有利于美观,代码有利于精确。

忽略用户的文化,除非作为默认选择的最佳猜测。(例如,如果他们是美国人,那么他们可能想使用美元,但可能不想)。世界上没有那么多货币,所以这里列出了除了一些专门的国际用例之外的所有货币:

AED  United Arab Emirates Dirham  د.إ
AFN  Afghan Afghani  ؋
ALL  Albanian Lek  L
AMD  Armenian Dram  դր
ANG  Netherlands Antillean Guilder  ƒ
AOA  Angolan Kwanza  Kz
ARS  Argentine Peso  $
AUD  Australian Dollar  $
AWG  Aruban Florin  ƒ
AZN  Azerbaijani Manat  man.
BAM  Bosnia and Herzegovina Convertible Mark  KM
BBD  Barbados Dollar  $
BDT  Bangladeshi Taka  ৳
BGN  Bulgarian Lev  лв
BHD  Bahraini Dinar  .د.ب
BIF  Burundian Franc  FBu
BMD  Bermudian Dollar  $
BND  Brunei Dollar  $
BOB  Boliviano  Bs.
BRL  Brazilian Real  R$
BSD  Bahamian Dollar  $
BTN  Bhutanese Ngultrum  Nu.
BWP  Botswana Pula  P
BYR  Belarusian Ruble  Br
BZD  Belize Dollar  $
CAD  Canadian Dollar  $
CDF  Congolese Franc  FC
CHF  Swiss Franc  Fr.
CLP  Chilean Peso  $
CNY  Chinese Yuan  ¥
COP  Colombian Peso  $
CRC  Costa Rican Colon  ₡
CUC  Cuban convertible Peso  $
CUP  Cuban Peso  $
CVE  Cape Verde Escudo  $
CZK  Czech Koruna  Kč
DJF  Djiboutian Franc  Fdj
DKK  Danish Krone  kr
DOP  Dominican Peso  $
DZD  Algerian Dinar  د.ج
EEK  Estonian Kroon  kr
EGP  Egyptian Pound  ج.م
ERN  Eritrean Nakfa  Nfk
ETB  Ethiopian Birr  Br
EUR  Euro  €
FJD  Fiji Dollar  $
FKP  Falkland Islands Pound  £
GBP  Pound Sterling (British Pound)  £
GEL  Georgian Lari  lari
GHS  Ghanaian Cedi  ₵
GIP  Gibraltar Pound  £
GMD  Gambian Dalasi  D
GNF  Guinean Franc  FG
GTQ  Guatemalan Quetzal  Q
GYD  Guyanese Dollar  $
HKD  Hong Kong Dollar  $
HNL  Honduran Lempira  L
HRK  Croatian Kuna  kn
HTG  Haitian Gourde  G
HUF  Hungarian Forint  Ft
IDR  Indonesian Rupiah  Rp
ILS  Israeli New Sheqel  ₪
INR  Indian Rupee  Rs
IQD  Iraqi Dinar  د.ع
IRR  Iranian Rial  ﷼
ISK  Icelandic Króna  kr
JMD  Jamaican Dollar  $
JOD  Jordanian Dinar  JD
JPY  Japanese Yen  ¥
KES  Kenyan Shilling  Ksh
KGS  Kyrgyzstani Som  som
KHR  Cambodian Riel  ៛
KMF  Comoro Franc  CF
KPW  North Korean Won  ₩
KRW  South Korean Won  ₩
KWD  Kuwaiti Dinar  د.ك
KYD  Cayman Islands Dollar  $
KZT  Kazakhstani Tenge  ₸
LAK  Lao Kip  ₭
LBP  Lebanese Pound  ل.ل
LKR  Sri Lanka Rupee  Rs
LRD  Liberian Dollar  $
LSL  Lesotho Loti  M
LTL  Lithuanian Litas  Lt
LVL  Latvian Lats  Ls
LYD  Libyan Dinar  ل.د
MAD  Moroccan Dirham  د.م.
MDL  Moldovan Leu  leu
MGA  Malagasy Ariary  ariary
MKD  Macedonian Denar  ден
MMK  Myanma Kyat  K
MNT  Mongolian Tögrög (Tugrik)  ₮
MOP  Macanese Pataca  毫
MRO  Mauritanian Ouguiya  UM
MUR  Mauritian Rupee  R
MVR  Maldivian Rufiyaa  .ރ
MWK  Malawian Kwacha  MK
MXN  Mexican Peso  $
MYR  Malaysian Ringgit  RM
MZN  Mozambican Metical  MTn
NAD  Namibian Dollar  $
NGN  Nigerian Naira  ₦
NIO  Nicaraguan Cordoba Oro  C$
NOK  Norwegian Krone  kr
NPR  Nepalese Rupee  रू.
NZD  New Zealand Dollar  $
OMR  Omani Rial  ر.ع.
PAB  Panamanian Balboa  ฿
PEN  Peruvian Nuevo Sol  S/.
PGK  Papua New Guinean Kina  K
PHP  Philippine Peso  ₱
PKR  Pakistani Rupee  Rs
PLN  Polish Zloty  zł
PYG  Paraguayan Guaraní  ₲
QAR  Qatari Rial  ر.ق
RON  Romanian New Leu  lei
RSD  Serbian Dinar  РСД
RUB  Russian Rouble  руб
RWF  Rwandan Franc  RF
SAR  Saudi Riyal  ر.س
SBD  Solomon Islands Dollar  $
SCR  Seychelles Rupee  SRe
SDG  Sudanese Pound  SDG
SEK  Swedish Krona  kr
SGD  Singapore Dollar  $
SHP  Saint Helena Pound  £
SLL  Sierra Leonean Leone  Le
SOS  Somali Shilling  So. Sh.
SRD  Surinamese Dollar  $
STD  São Tomé and Príncipe Dobra  Db
SYP  Syrian Pound  SYP
SZL  Lilangeni  E
THB  Thai Baht  ฿
TJS  Tajikistani Somoni  TJS
TMT  Turkmenistani Manat  m
TND  Tunisian Dinar  د.ت
TOP  Tongan Paʻanga  T$
TRY  Turkish Lira  TL
TTD  Trinidad and Tobago Dollar  $
TWD  New Taiwan Dollar  $
TZS  Tanzanian Shilling  TZS
UAH  Ukrainian Hryvnia  ₴
UGX  Ugandan Shilling  Ush
USD  United States Dollar  $
UYU  Uruguayan Peso  $
UZS  Uzbekistan Som  som
VEF  Venezuelan Bolívar Fuerte  Bs. F
VND  Vietnamese Ðồng  ₫
VUV  Vanuatu Vatu  Vt
WST  Samoan Tala  WS$
XAF  CFA Franc BEAC  FCFA
XCD  East Caribbean Dollar  $
XOF  CFA Franc BCEAO  CFA
XPF  CFP Franc  F
YER  Yemeni Rial  rial
ZAR  South African Rand  R
ZMK  Zambian Kwacha  ZK
ZWL  Zimbabwe Dollar  $

哦,看。上次我更新时津巴布韦有自己的美元。哪种情况发生得更快,你把它从列表中删除,或者更新一个框架来做到这一点?

以下是如何在c#中使用字符串进行操作。format:

decimal amount = 2130 / 100M;
string output = string.Format("{0:c}", amount);

这将为您提供当前文化的格式。MSDN 的更多信息

尝试以下操作:

 decimal amount = 2130 / 100m;
 string output = value.ToString("C", CultureInfo.CurrentCulture);
decimal value = ((decimal)(myNumber / 100.0));
var result = String.Format("{0:c}", value);