//输入数字型金额,返回中文大写金额
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(".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;}