欢迎光临
我们一直在努力

一个把数字转英文的实用程序

建站超值云服务器,限时71元/月

最近做项目的合同部分时用到需要能把数字转英文的程序,找过很多网站都没用,只能安下心来自己做,程序作的不太精简,但功能可以实现,也许同僚们会用得着。(vbscript)

function zr4(y)准备数据

dim z(10)

z(1)="one"

z(2)="two"

z(3)="three"

z(4)="four"

z(5)="five"

z(6)="six"

z(7)="seven"

z(8)="eight"

z(9)="nine"

zr4=z(mid(y,1,1))

end function

function zr3(y)准备数据

dim z(10)

z(1)="one"

z(2)="two"

z(3)="three"

z(4)="four"

z(5)="five"

z(6)="six"

z(7)="seven"

z(8)="eight"

z(9)="nine"

zr3=z(mid(y,3,1))

end function

function zr2(y)准备数据

dim z(20)

z(10)="ten"

z(11)="eleven"

z(12)="twelve"

z(13)="thirteen"

z(14)="fourteen"

z(15)="fifteen"

z(16)="sixteen"

z(17)="seventeen"

z(18)="eighteen"

z(19)="nineteen"

zr2=z(mid(y,2,2))

end function

function zr1(y)准备数据

dim z(10)

z(1)="ten"

z(2)="twenty"

z(3)="thirty"

z(4)="forty"

z(5)="fifty"

z(6)="sixty"

z(7)="seventy"

z(8)="eighty"

z(9)="ninety"

zr1=z(mid(y,2,1))

end function

function dw(y)准备数据

dim z(5)

z(0)=""

z(1)="thousand"

z(2)="million"

z(3)="billion"

dw=z(y)

end function

function w2(y)用来制作2位数字转英文

if mid(y,2,1)="0" then判断是否小于十

value=zr3(y)

elseif mid(y,2,1)="1" then判断是否在十到二十之间

value=zr2(y)

elseif mid(y,3,1)="0" then判断是否为大于二十小于一百的能被十整除的数(为了去掉尾空格)

value=zr1(y)

else

value=zr1(y)+" "+zr3(y)加上十位到个位的空格

end if

w2=value

end function

function w3(y)用来制作3位数字转英文

if mid(y,1,1)="0" then判断是否小于一百

value=w2(y)

elseif mid(y,2,2)="00" then判断是否能被一百整除

value=zr4(y)+" "+"hundred"

else

value=zr4(y)+" "+"hundred"+" "+"and"+" "+w2(y)不能整除的要后面加“and”

end if

w3=value

end function

function make(x)

z=instr(1,x,".",1)取小数点位置

if z<>0 then判断有没有小数

lstr=mid(x,1,z-1)取小数点左边的字串

rstr=mid(x,z+1,2)取小数点右边的字串

else

lstr=x没有小数的情况

end if

lstrev=strreverse(lstr)对左边的字串取反字串

dim a(5)定义5个字串变量用来存放解析出的三位一组的字串

select case len(lstrev) mod 3字串长度不能被整除,需补齐

case "1"

lstrev=lstrev+"00"

case "2"

lstrev=lstrev+"0"

end select

lm=""用来存放转换后的整数部分

for i=0 to len(lstrev)/3-1计算有多少个三位

a(i)=strreverse(mid(lstrev,3*i+1,3))截取第1个三位

if a(i)<>"000" then用来避免这种情况“1000000=one million thousand only”

if i<>0 then

lm=w3(a(i))+" "+dw(i)+" "+lm用来加上“thousand or million or billion”

else

lm=w3(a(i))防止i=0时“lm=w3(a(i))+" "+dw(i)+" "+lm”多加两个尾空格

end if

else

lm=w3(a(i))+lm

end if

next

xs=""用来存放转换后的小数部分

if z<>0 then

xs="and cents"+" "+w2("$"+rstr)+" "小数部分存在时转换小数部分

end if

make=lm+" "+xs+"only"最后结果,加上only

end function

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 一个把数字转英文的实用程序
分享到: 更多 (0)