#include <afx.h>
#include <stdio.h>
CString ChineseCapitalMoney(double Num)
{
CString szChMoney,szNum;
int iLen, iNum, iAddZero=0;
TCHAR* hzUnit[18]={_T("分"),_T("角"),_T("元"),_T("拾"),_T("佰"),_T("仟"),_T("万"),_T("拾"),_T("佰"),_T("仟"),_T("亿"),_T("拾"),_T("佰"),_T("仟"),_T("万"),_T("拾"),_T("佰"),_T("仟")};
TCHAR* hzNum[10]={_T("零"),_T("壹"),_T("贰"),_T("叁"),_T("肆"),_T("伍"),_T("陆"),_T("柒"),_T("捌"),_T("玖")};
if (-0.01<Num && Num<0.01) return _T("零元整");
szNum.Format(_T("%18.0f"), Num*100); // 最小到分
szNum.TrimLeft();
iLen=szNum.GetLength();
if(iLen>15 || iLen==0 || Num<0) return _T(""); // 数据错误返回
for(int i=0;i<iLen;i++) {
iNum=_ttoi((LPCTSTR)szNum.Mid(i,1));
if (iNum==0) {
iAddZero++;
} else {
if (iAddZero>0) szChMoney+=_T("零");
szChMoney+=hzNum[iNum];
iAddZero=0;
}
if (iNum!=0 || iLen-i==3 || iLen-i==11 || ((iLen-i+1)%8==0 && iAddZero<4)) szChMoney+=hzUnit[iLen-i-1];
}
if (szNum.Right(2)==_T("00")) szChMoney+=_T("整"); // 没有角和分
return szChMoney;
}
void main()
{
double d;
CString s;
d=-1.0 ;printf("%16.2f %s\n",d,ChineseCapitalMoney(d));
d=0.0 ;printf("%16.2f %s\n",d,ChineseCapitalMoney(d));
d=1234501234567.89;printf("%16.2f %s\n",d,ChineseCapitalMoney(d));
d=1000000000000.01;printf("%16.2f %s\n",d,ChineseCapitalMoney(d));
d=1000000000001.00;printf("%16.2f %s\n",d,ChineseCapitalMoney(d));
}
// -1.00
// 0.00 零元整
//1234501234567.89 壹万贰仟叁佰肆拾伍亿零壹佰贰拾叁万肆仟伍佰陆拾柒元捌角玖分
//1000000000000.01 壹万亿元零壹分
//1000000000001.00 壹万亿零壹元整