PowerBuilder文摘
首页 | 原创 | 译文 | 转载 | 源码 | 工具 | 灌水 | 全部 | PB助手 | 相册 | 留言 | 登陆 | 注册
将人民币金额转换成大写的金额
2006年6月30日01:48星期五  [转载]

提供两种方法:

//////////////////////////////////////////////////////////////////////
//将钱数转化为大写
//////////////////////////////////////////////////////////////////////
constant string ls_bit = "万仟佰拾亿仟佰拾万仟佰拾元角分"
constant string ls_num = "壹贰叁肆伍陆柒捌玖"
long lmax = len( ls_bit ) + 1
string ls_je, ls_dw, ls_result = ''
long ll_len, i, k
ls_je = string( data, "#############.00" )
ll_len = len( ls_je ) - 1
ls_je = replace( ls_je, ll_len - 1, 1, '' )
for i = ll_len to 1 step -1
lmax -= 2
ls_dw = mid( ls_bit, lmax, 2 )
k = long( mid( ls_je, i, 1 ) )
if k = 0 then
choose case ls_dw
case '元','万','亿'
ls_result = ls_dw + ls_result
case '分'
ls_result = '整'
case '角'
if ls_result <> '整' then ls_result = '零' + ls_result
case else
choose case left( ls_result, 2 )
case '万', '亿', '元', '零'
case else
ls_result = '零' + ls_result
end choose
end choose
else
ls_result = mid( ls_num, k * 2 - 1, 2 ) + ls_dw + ls_result
end if
next
return ls_result


--------------------------------------------------------
//入口参数:DECIMAL numb
INTEGER i //循环变量
STRING s_numb //以字符串表示
STRING s_money
INTEGER i1
s_numb = String(numb,"########.00")
IF Len(s_numb) < 11 THEN s_numb = Space(11-len(s_numb))+s_numb
i = 1
s_money = ""
//去掉前导空格
DO WHILE i<8 AND Mid(s_numb,i,1) = " "
i ++
LOOP

i1 = 11 - i + 1

INTEGER digit
DO WHILE i<=4
digit = Integer(Mid(s_numb,i,1))
IF digit = 0 THEN
DO WHILE i<=4
digit = Integer(Mid(s_numb,i,1))
IF digit <>0 THEN exit
i ++
LOOP
IF i<=4 THEN s_money += "零"
ELSE
s_money += Mid("壹贰叁肆伍陆柒捌玖",digit*2-1,2) +&
Mid("仟佰拾万",i*2-1,2)
i ++
END IF
LOOP

IF i1 >= 8 THEN
IF Integer(Mid(s_numb,4,1)) = 0 THEN s_money += "万"
END IF

DO WHILE i<=8
digit = Integer(Mid(s_numb,i,1))
IF digit = 0 THEN
DO WHILE i<=8
digit = Integer(Mid(s_numb,i,1))
IF digit<>0 THEN exit
i ++
LOOP
IF i<=8 THEN
s_money += "零"
ELSE
IF Integer(Mid(s_numb,1,8)) <> 0 THEN
s_money += "元"
IF Integer(Mid(s_numb,11,1))<>0 THEN s_money += "零"
END IF
END IF
END IF
IF digit <> 0 THEN
s_money += Mid("壹贰叁肆伍陆柒捌玖",digit*2-1,2) + &
Mid("仟佰拾万仟佰拾元",i*2-1,2)
END IF
i ++
LOOP

digit = Integer(Mid(s_numb,10,1))
IF digit<>0 THEN
s_money += Mid("壹贰叁肆伍陆柒捌玖",digit*2-1,2) + "角"
ELSE
IF Integer(Mid(s_numb,11,1))<>0 AND Integer(Mid(s_numb,1,9)) <> 0 THEN
s_money += "零"
END IF
END IF

digit = Integer(Mid(s_numb,11,1))
IF digit <> 0 THEN
s_money += Mid("壹贰叁肆伍陆柒捌玖",digit*2-1,2) + "分"
ELSE
IF Len(Trim(s_money)) <> 0 THEN s_money += "整"
END IF

RETURN s_money

摘自: http://www.computernews.com.cn/Article/2004-10-13/4368.html

字体:
Posted by tigerchamp | 评论(7) | 阅读1894次
awesome seo在 2014年6月23日08:31星期一 评论:
NHZnqa A round of applause for your blog post. Much obliged.

hairdressers melbour在 2014年6月10日05:14星期二 评论:
Wow, great post.Really looking forward to read more.

cheap viagra for sale在 2012年11月10日00:27星期六 评论:
mais bientot apres il retomba et se trouva tout,

crork在 2012年10月27日15:05星期六 评论:
jSYEnK Appreciate you sharing, great article post. Will read on...

serivce在 2012年5月15日08:28星期二 评论:
uXkU9F I loved your blog post.Really looking forward to read more. Will read on...

cxjevtb在 2006年10月25日16:34星期三 评论:
ޱ޼ʵ,QQ384065847

ngywhdm在 2006年8月30日22:44星期三 评论:
,λ502883970

称呼:    登陆   注册
   不注册,但记住我的信息
邮件:
(非必须)
评论: [UBB代码帮助]
粗体 斜体 下划线 链接 水平线 引用



提交时自动将内容复制到剪贴板