• 金额转换大写


      **FOR UNICODE 系统:
    REPORT  z_barry_test NO STANDARD PAGE HEADING .
    TYPES: CUR6  TYPE P DECIMALS 6 ,
           CUR2  TYPE P DECIMALS 2 .
    DATA VA1 TYPE CUR2.
    DATA STR(40TYPE C .
    VA1 = '123456'.
    PERFORM CONV_AMOUNT USING VA1
                        CHANGING STR.
    WRITE STR.
    *&--------------------------------------------------------------------*
    *&      Form  conv_amount
    *&--------------------------------------------------------------------*
    FORM CONV_AMOUNT USING VALUE(F_SOURCE)
                     CHANGING VALUE(F_RESULT).
      DATA: SCR(30TYPE C, RES(60TYPE C,FEN(2TYPE C .
      DATA: LEN TYPE I, C1 TYPE I, C2 TYPE I, C3 TYPE I, C4 TYPE I.
      DATA: D1(1TYPE C, D2(1TYPE C, D3 TYPE I.
      DATA: DIGIT(2TYPE C, WEIGHT(2TYPE C.
      DATA: RULE1(20TYPE C VALUE '零壹贰叁肆伍陆柒捌玖'.
      DATA: RULE2(30TYPE C VALUE '分角元拾佰仟万拾佰仟亿拾佰仟万'.
      SCR = F_SOURCE * 100.
      CONDENSE SCR NO-GAPS.
      IF SCR = '0'.
        RES = '零元'.
      ELSE.
        LEN = STRLEN( SCR ).
        C1 = 0.
        D1 = '0'.
        CLEAR RES.
        DO LEN TIMES.
          C1 = C1 + 1.
          C2 = LEN - C1.
          D2 = SCR+C2(1) .
          IF D2 = '0'.
            D3 = 0.
          ELSE.
            D3 = D2.
          ENDIF.
          DIGIT = RULE1+D3(1) .
          C3 = ( C1 - 1 ) .
          WEIGHT = RULE2+C3(1) .
          IF D2 = '0'.
            IF C1 = 3.
              DIGIT = ''.
            ELSEIF C1 = 7.
              DIGIT = ''.
              IF LEN > 10 .
                C4 = LEN - 10.
                IF SCR+C4(4) = '0000'.
                  WEIGHT = ''.
                ENDIF.
              ENDIF.
            ELSEIF C1 = 11.
              DIGIT = ''.
            ELSEIF D1 = '0'.
              DIGIT = ''.
              WEIGHT = ''.
            ELSE.
              WEIGHT = ''.
            ENDIF.
          ENDIF.
          CONCATENATE DIGIT WEIGHT RES INTO RES .
          D1 = D2.
        ENDDO.
      ENDIF.
      LEN = STRLEN( RES ) - 1.
      FEN = RES+LEN(1).
      IF FEN <> '分' .
        CONCATENATE RES '整' INTO F_RESULT.
      ELSE.
        F_RESULT = RES.
      ENDIF.
    ENDFORM.                    "conv_amount
  • 相关阅读:
    SQL Server 排序实现函数细说
    hibernate的11大优势
    JSP开发使用JSTL和EL表达式问题
    Java开源框架集
    Struts实现登陆
    如何取得ResultSet的行数
    SQL Server2005 ROW_NUMBER() OVER 使用
    Struts中perform方法1.2.4版本以后都不在使用
    家长会随笔
    几何画板图像复制
  • 原文地址:https://www.cnblogs.com/elegantok/p/1571324.html
Copyright © 2020-2023  润新知