//输入数字型金额,返回中文大写金额
CString toChineseCapitalMoney(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("玖")};
szNum.Format(_T("%18.0f"), Num*100); //这样可能会有数字误差,double只有15位有效数字,这里只有13
szNum.TrimLeft();
iLen=szNum.GetLength();
if(iLen>15 || iLen==0 || Num<0)return ""; //数据错误返回
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)) //该位不为0||元位||亿位||万位
szChMoney+=hzUnit[iLen-i-1];
}
if(szNum.Right(2)==_T("00")) szChMoney+=_T("整");
return szChMoney;
}
本文地址:http://com.8s8s.com/it/it2823.htm