第1个回答 2010-09-10
有几种方法都能实现你的要求。
其中一种是这样:=IF(B1<0,"金额为负无效",
(IF(OR(B1=0,B1=""),"(人民币)零元",
IF(B1<1,"(人民币)",
TEXT(INT(B1),"[dbnum2](人民币)G/通用格式")&"元"))))&
IF(
(INT(B1*10)-INT(B1)*10)=0,
IF(INT(B1*100)-INT(B1*10)*10=0,"","零"),
(TEXT(INT(B1*10)-INT(B1)*10,"[dbnum2]")&"角"))
&IF(
(INT(B1*100)-INT(B1*10)*10)=0,
"整",
TEXT((INT(B1*100)-INT(B1*10)*10),"[dbnum2]")&"分")
如果还有不明白的,直接HI我,就可以。
第2个回答 2010-09-10
推荐一个网友的答案:
Function da(M)
y = Int(Round(100 * Abs(M)) / 100)
j = Round(100 * Abs(M) + 0.00001) - y * 100
f = (j / 10 - Int(j / 10)) * 10
A = IIf(y < 1, "", Application.Text(y, "[DBNum2]") & "元")
b = IIf(j > 9.5, Application.Text(Int(j / 10), "[DBNum2]") & "角", IIf(y < 1, "", IIf(f > 1, "零", "")))
c = IIf(f < 1, "整", Application.Text(Round(f, 0), "[DBNum2]") & "分")
da = IIf(Abs(M) < 0.005, "", IIf(M < 0, "负" & A & b & c, A & b & c))
End Function
此程序为自定义函数程序,与普通的excel内嵌函数用法一样。
按alt加F11打开vba编辑器,新建模块,粘贴上面的代码,保存退出。
例 a1 为1000的话要在a2得到大写 在a2输入=da(a1)即等于壹仟圆整。
第3个回答 2010-09-10
呵呵 给你一个公式看看:
=IF(ROUND(E13,2)<0,"无效数值",IF(ROUND(E13,2)=0,"零",IF(ROUND(E13,2)<1,"",TEXT(INT(ROUND(E13,2)),"[dbnum2]")&"元")&IF(INT(ROUND(E13,2)*10)-INT(ROUND(E13,2))*10=0,IF(INT(ROUND(E13,2))*(INT(ROUND(E13,2)*100)-INT(ROUND(E13,2)*10)*10)=0,"","零"),TEXT(INT(ROUND(E13,2)*10)-INT(ROUND(E13,2))*10,"[dbnum2]")&"角")&IF((INT(ROUND(E13,2)*100)-INT(ROUND(E13,2)*10)*10)=0,"整",TEXT((INT(ROUND(E13,2)*100)-INT(ROUND(E13,2)*10)*10),"[dbnum2]")&"分")))
如果你登录 club.excelhome.net 搜索一下,将发现不下10中公式
第4个回答 2010-09-10
可以将输出列的格式设为"特殊"-"中文大写数字"
但是不是货币类型的
不过可以通过vba解决
第5个回答 2010-09-10
在格式菜单下的单元格选项中,把格式换为文本格式就可以了。
Excel里常有这种问题,因为默认的是数值输入模式,0的位置不对的话就经常会被忽略掉。改为文本模式后,数值都当做文本来处理,就不会有这种问题了。