首页 | 社区 | 博客 | 招聘 | 文章 | 新闻 | 下载 | 读书 | 代码
亲,您未登录哦! 登录 | 注册

在PB中实现数字的英文大写和中文大写

打印文章

分享到:
无锡市房产管理局产权监理处 陆建新

---- PowerBuilder是当前得到广泛应用的C/S数据库前端开发工具, 在使用PB的过程中,经常遇到要将数字进行英文或中文的大写转换,尤其是在处理金额的时候,本文整理了我在实践中用到的转换方法,提供给大家参考。

---- 一、 英文大写转换

---- 以下是进行英文大写转换的函数内容,函数名为dtoe:

//****** 阿拉伯数--- >英文数 ******
string aa,bb,T1,T2,T3,B,W,CC,a1
decimal a=0,c=0,a2
INTEGER V,M

aa="ONE      TWO      THREE    FOUR     
FIVE     SIX      SEVEN    "+&
   "EIGHT    NINE     TEN      ELEVEN   TWELVE
    THIRTEEN FOURTEEN FIFTEEN  "+&
   "SIXTEEN  SEVENTEENEIGHTEEN NINETEEN "
bb="TWENTY THIRTY FORTY  FIFTY  SIXTY  SEVENTYEIGHTY NINETY "

//**** 进入时 --- > t
T=round(t,2)
T1=STRING(T)
DO WHILE POS(T1,",")< >0
  V=POS(T1,",")
  T1=MID(T1,1,V - 1)+MID(T1,V+1)
LOOP
T2=" "
T3=T1
IF POS(T3,".")< >0 THEN
  V=POS(T3,".")
  T1=MID(T3,1,V - 1)
  T2=MID(T3,V+1)
END IF
T1=SPACE(10 - LEN(T1))+T1
CC=T1
B=" "
W=" "
M=9
//*** 整数处理 ***
do while m >0
  if MID(cc,m+1,1)=" " then
    exit
  end if
  if INTEGER(MID(cc,m - 1,3))< >0 then
    if m=6 then
      W=" THOUSAND "+w
    else
      if m=3 then
        W=" MILLION "+w
      end if
    end if
    A=INTEGER(MID(cc,m,2))
//***  小于 100 的数  ***
    if a< >0 then
      if a< 20 then
        B=RIGHTtrim(MID(aa,(a - 1)*9+1,9))
      else
        A1=STRING(a,'00')
        A2=INTEGER(MID(a1,1,1))
        b=RIGHTtrim(mid(bb,(a2 - 2)*7+1,7))
        a2=INTEGER(MID(a1,2,1))
        if a2< >0 then
          B=RIGHTtrim(b+"-"+MID(aa,(a2 - 1)*9+1,9))
        end if
      end if
      W=b+w
    end if
    A=INTEGER(MID(cc,m - 1,1))
//***  100--999 的数  ***
    if a< >0 then
      b=RIGHTtrim(mid(aa,(a - 1)*9+1,9))+" HUNDRED "
      if w< >" "  and m=9 then
        b=b+"AND "
      end if
      w=b+w
    end if
  end if
  m=m - 3
LOOP
//*** 小数处理 ***
if w=" " then
  w="ZERO "
end if
if t2< >" "  AND T2< >"00" then
  w=trim(w)+" & "+t2+"/100"
end if
//*** 结果 --- > w
return w

---- 二、中文大写转换

---- 以下是进行中文大写转换的函数内容,函数名为dtormb:

decimal y
string je,x,hz1,hz2,e,h,f,m
int b,a
y=mje
X = trim(string(Y))
B = len(X)-3
A = 1
E = mid(X,A,1)
HZ2 = '零壹贰叁肆伍陆柒捌玖'
HZ1 = '仟佰拾亿仟佰拾万仟佰拾元'
JE = ' '
do while E< >'.'
  H = mid(HZ2,integer(E)*2+1,2)
  F = mid(HZ1,24 - (B - A)*2 - 1,2)
  if E< >'0' or (E='0' and (F='亿' or F='万' or F='元')) then
    JE = trim(JE)+H+F
  else
    JE = trim(JE)+H
  end if
  A = A+1
  E = mid(X,A,1)
loop
A = A+1
E = mid(X,A,1)
H = mid(X,A+1,1)
if E='0' and H='0' then
  JE = JE+'整'
else
  if E='0' then
    JE = JE+'零'+mid(HZ2,integer(H)*2+1,2)+'分'
  else
    if H='0' then
      JE = JE+mid(HZ2,integer(E)*2+1,2)+'角整'
    else
      JE = JE+mid(HZ2,integer(E)*2+1,2)
           +'角'+mid(HZ2,integer(H)*2+1,2)+'分'
    end if
  end if
end if
B = len(JE)
A = 1
do while A< B
  M = mid(JE,A,4)
  if M='零元' or M='零万' or M='零亿' or M='零零' then
    JE = mid(JE,1,A - 1)+trim(mid(JE,A+2,40))
    A = A - 2
    B = B - 2
  end if
  A = A+2
loop
return JE

本栏文章均来自于互联网,版权归原作者和各发布网站所有,本站收集这些文章仅供学习参考之用。任何人都不能将这些文章用于商业或者其他目的。( Pfan.cn )

编程爱好者论坛

本栏最新文章