易宝电子贸易管理软件论坛

注册

 

发新话题 回复该主题

[分享] 水晶报表打印格式金额转成中文大写函数 [复制链接]

1#
银光图片
在水晶报表,公式工作室中新建报表自定义函数,函数内容如下:

Function (stringvar number)
(
  stringvar str1 := "零壹贰叁肆伍陆柒捌玖";            //0-9所对应的汉字
  stringvar str2 := "万仟佰拾亿仟佰拾万仟佰拾元角分"; //数字位所对应的汉字
  stringvar str3 := "";    //从原num值中取出的值
  stringvar str4 := "";    //数字的字符串形式
  stringvar str5 := "";  //人民币大写金额形式
  numbervar i:=0;    //循环变量
  numbervar j:=0;    //num的值乘以100的字符串长度
  stringvar ch1 := "";    //数字的汉语读法
  stringvar ch2 := "";    //数字位的汉字读法
  numbervar nzero := 0;  //用来计算连续的零值是几个
  numbervar temp;            //从原num值中取出的值

  numbervar num := Round(Abs(tonumber(number)),2);    //将num取绝对值并四舍五入取2位小数
  str4 := totext(tonumber(num*100),0);        //将num乘100并转换成字符串形式
  str4:=replace(str4,",","");
  j := Length(str4);      //找出最高位
  if j > 15 then
    "字符串太长"
  else
  (
      str2 := mid(str2,15-j+1);   //取出对应位数的str2的值。如:200.55,j为5所以str2=佰拾元角分

      //循环取出每一位需要转换的值
      for i:=1 to j step 1 do
      (
          str3 :=mid(str4,i,1);          //取出需转换的某一位的值
          temp := int(tonumber(str3));      //转换为数字
          if (i <> (j-3) and i <> (j-7) and i <> (j-11) and i <> (j-15))  then
          (    
               //当所取位数不为元、万、亿、万亿上的数字时
               if (str3 = "0") then
               (
                   ch1 := "";
                   ch2 := "";
                   nzero := nzero + 1;
               )
               else
               (
                  if(str3 <> "0" and nzero <> 0) then
                  (
                      ch1 := "零" + mid(str1,temp*1+1,1);
                      ch2 := mid(str2,i,1);
                      nzero := 0;
                  )
                  else
                  (
                      ch1 := mid(str1,temp*1+1,1);
                      ch2 := mid(str2,i,1);
                      nzero := 0;
                   )
                )
           )
           else
           (
                //该位是万亿,亿,万,元位等关键位  
                if (str3 <> "0" and nzero <> 0)  then
                (
                    ch1 := "零" + mid(str1,temp*1+1,1);
                    ch2 := mid(str2,i,1);
                    nzero := 0;
                )
                else
                (
                    if (str3 <> "0" and nzero = 0) then
                    (
                         ch1 := mid(str1,temp*1+1,1);
                         ch2 := mid(str2,i,1);
                         nzero := 0;
                     )
                    else
                    (
                         if (str3 = "0" and nzero >= 3) then
                         (
                             ch1 := "";
                             ch2 := "";
                             nzero := nzero + 1;
                          )
                          else
                          (
                              if (j >= 11)  then
                              (
                                  ch1 := "";
                                  nzero := nzero + 1;
                              )
                              else
                              (
                                  ch1 := "";
                                  ch2 := mid(str2,i,1);
                                  nzero := nzero + 1;
                              )
                          )
                      )
                  )
             );

             if (i = (j-11) or i = (j-3)) then
             (  
                if(mid(str4,j,1)="0" and mid(str4,j-1,1)="0" and mid(str4,j-2,1)="0" and mid(str4,j-3,1)="0") then
                (
                    ch2:='元';////460000.00-肆拾陆万拾整
                )
                else if(j=6 and mid(str4,j,1)="0" and mid(str4,j-1,1)="0" and mid(str4,j-3,1)="0") then
                (
                    ch2:='';////1408.00-壹仟肆佰拾零捌元整
                )
                else if((j=5 or j=6) and mid(str4,j,1)="0" and mid(str4,j-1,1)<>"0" and mid(str4,j-2,1)="0") then
                (
                    ch2:=ch2+'元';////3590.40-叁仟伍佰玖拾零肆角/770.70-柒佰柒拾零柒角
                )
                else if(j=7 and mid(str4,j-3,1)="0" and mid(str4,j-2,1)<>"0") then
                (
                    ch2:='';////14704.00-壹万肆仟柒佰拾零肆元整
                )
                else
                (
                    //如果该位是亿位或元位,则必须写上
                    ch2 := mid(str2,i,1);
                )
             ) ;
             if(j=8 and i=3 and mid(str4,j-5,1)="0" and mid(str4,j-6,1)="0") then
             (
                ch2:='万';////100800.00-壹拾零捌佰元整
              );

             str5 := str5 + ch1 + ch2;            

             if (i = j-1 and str3 = "0")  then
             (
                ////80.00-捌拾整
                if(InStr(str5, '元') = 0) then
                (
                    str5 := str5 + '元';
                );
                //最后一位(分)为0时,加上“整”
                str5 := str5 + '整';
             ) ;
       );




         if (num = 0) then
         (
             str5 := "零元整";
         ) ;  
          str5
    )
)
金额中文大写.jpg (, 下载次数:0)

(2016/6/28 10:05:02 上传)

金额中文大写.jpg

最后编辑huangyf 最后编辑于 2016-06-28 10:05:02
分享 转发
TOP
发新话题 回复该主题