FUNCTION zzfi_change_amount.
*"----------------------------------------------------------------------
*"*"本地接口:
*"  IMPORTING
*"     REFERENCE(I_MONEY) TYPE  BF_DMBTR
*"  EXPORTING
*"     REFERENCE(O_MONEY)
*"  EXCEPTIONS
*"      WRONG_MONEY
*"----------------------------------------------------------------------
  DATA:
    v_s00(2)     VALUE '零',
    v_s01(2)     VALUE '壹',
    v_s02(2)     VALUE '贰',
    v_s03(2)     VALUE '叁',
    v_s04(2)     VALUE '肆',
    v_s05(2)     VALUE '伍',
    v_s06(2)     VALUE '陆',
    v_s07(2)     VALUE '柒',
    v_s08(2)     VALUE '捌',
    v_s09(2)     VALUE '玖',
    v_w00(2)     VALUE '',
    v_w01(2)     VALUE '拾',
    v_w02(2)     VALUE '佰',
    v_w03(2)     VALUE '仟',
    v_w04(2)     VALUE '万',
    v_w05(4)     VALUE '拾',
    v_w06(4)     VALUE '佰',
    v_w07(4)     VALUE '仟',
    v_w08(2)     VALUE '亿',
    v_w09(4)     VALUE '拾',
    v_w10(4)     VALUE '佰',
    v_w11(4)     VALUE '仟',
    v_w12(4)     VALUE '万',
    v_sy(2)      VALUE '元',
    v_sj(2)      VALUE '角',
    v_sf(2)      VALUE '分',
    v_amount(16),"将金额转换成字符型
    v_len        TYPE i, "v_amount或out的长度
    v_var(5),"v_s0,v_s1,...,v_w0,v_w1,...
    v_num(2)     TYPE n, "每一位的数值
    v_s_num(2),"v_s0,v_s1,...中的值
    v_weight(2)  TYPE n, "权数
    v_w_num(4),"v_w0,v_w1,...中的值
    v_flag0      TYPE i VALUE 0, "是否输出'零',0不输出,1输出
    v_n          TYPE i VALUE 0,
    v_index      TYPE sy-index.
  v_amount = i_money.
  SHIFT v_amount LEFT DELETING LEADING space.
  SHIFT v_amount LEFT DELETING LEADING '0'.
*-计算分-----------------------------------------
  v_len = strlen( v_amount ).
  v_len = v_len - 1.
  v_num = v_amount+v_len(1).
  IF v_num <> '0'.
    CONCATENATE 'v_s' v_num INTO v_var.
    WRITE (v_var) TO v_s_num.
    CONCATENATE v_s_num v_sf o_money INTO o_money.
  ENDIF.
*-计算角-----------------------------------------
  v_len = strlen( v_amount ).
  v_len = v_len - 2.
  v_num = v_amount+v_len(1).
  IF v_num <> '0'.
    CONCATENATE 'v_s' v_num INTO v_var.
    WRITE (v_var) TO v_s_num.
    CONCATENATE v_s_num v_sj o_money INTO o_money.
  ENDIF.
*-输出‘整’字-------------------------------------
  IF o_money = ' '.
    CONCATENATE '整' o_money INTO o_money.
  ENDIF.
*-计算整数---------------------------------------
  v_len = strlen( v_amount ).
  v_len = v_len - 3.
  IF v_len = 0.
    EXIT.
  ENDIF.
  v_amount = v_amount(v_len)." 整数部分
*-输出‘元’字-------------------------------------
  CONCATENATE v_sy o_money INTO o_money.
  v_n = v_len - 1.
  v_weight = 0.
  DO v_len TIMES.
    v_index = sy-index.
*   从个位开始
    v_num = v_amount+v_n(1).
    IF v_num <> '0'.
      CONCATENATE 'v_s' v_num INTO v_var.
      WRITE (v_var) TO v_s_num.
      CONCATENATE 'v_w' v_weight INTO v_var.
      WRITE (v_var) TO v_w_num.
      CONCATENATE v_s_num v_w_num o_money INTO o_money.
      v_flag0 = 1.
    ELSE.
      IF v_flag0 = 1.
        CONCATENATE 'v_s' v_num INTO v_var.
        WRITE (v_var) TO v_s_num.
        CONCATENATE v_s_num o_money INTO o_money.
        v_flag0 = 0.
      ENDIF.

IF v_index = 5  AND v_len > 5 AND v_len < 9 .
        CONCATENATE '万' o_money INTO o_money.
      ELSEIF v_index = 9 AND v_len > 9.
        CONCATENATE '亿' o_money INTO o_money.
      ENDIF.

*      CASE SY-INDEX.
*        WHEN 5.CONCATENATE '万' OUT INTO OUT.
*        WHEN 9.CONCATENATE '亿' OUT INTO OUT.
*      ENDCASE.
    ENDIF.
    v_weight = v_weight + 1.
    v_n = v_n - 1.
  ENDDO.
*-删除个位可能出现'零'的情况-----------------
  SEARCH o_money FOR '圆'.
  IF sy-subrc = 0.
    v_n = sy-fdpos - 2.
    IF v_n >= 0.
      IF o_money+v_n(2) = v_s00.
        v_len = strlen( o_money ).
        CONCATENATE o_money(v_n) o_money+sy-fdpos INTO o_money.
      ENDIF.
    ENDIF.
  ENDIF.

ENDFUNCTION.

ABAP 金额转换成大写的更多相关文章

  1. C#小写数字金额转换成大写人民币金额的算法

    C#小写数字金额转换成大写人民币金额的算法 第一种方法: using System.Text.RegularExpressions;//首先引入命名空间 private string DaXie(st ...

  2. SQL函数:小写金额转换成大写

    /********************************************************作者:版本:1.0创建时间:20020227修改时间:功能:小写金额转换成大写参数:n ...

  3. 用python实现把数字人民币金额转换成大写的脚本程序

    # -*- coding: utf-8 -*- def Num2MoneyFormat( change_number ): """ .转换数字为大写货币格式( forma ...

  4. jquery 金额转换成大写

    <script language="javascript" type="text/javascript">         function Ara ...

  5. JavaScript将小写金额转换成大写

    //num为小写金额,单位元 changeMoney(num) { if(isNaN(num))return ""; var strPrefix=""; if( ...

  6. irport报表,把数字金额转换成大写人民币金额

    1.编写oracle函数 CREATE OR REPLACE Function MoneyToChinese(Money In Number) Return Varchar2 Is strYuan ) ...

  7. 【PHP】金额数字转换成大写形式

    <?php /*将数字金额转成大写*/ function num_to_upper($num) { $d = array('零','壹','贰','叁','肆','伍','陆','柒','捌', ...

  8. JS把数字金额转换成中文大写数字的函数

    //把数字金额转换成中文大写数字的函数 function num2rmb ($num){ $c1="零壹贰叁肆伍陆柒捌玖"; $c2="分角元拾佰仟万拾佰仟亿" ...

  9. PHP算法--将数字金额转换成大写金额

    最近在看一些PHP算法题,遇到一个将数字金额转换成大写金额的小算法题,这里贴出自己的一个例子. 注:这个小算法适用于10万以内的金额. <?php //$num = 12345.67; func ...

随机推荐

  1. JAVA基础之JDK安装

    JDK的安装与环境变量配置是JAVA开发之路的第一步,很多新人在这一步上就卡了很久,浪费了很多时间,甚至有些人就轻易地“从入门到放弃”了. 今天我们就来一步步教你如何打倒这第一只拦路虎. 1.JDK下 ...

  2. python接口自动化(二十九)--html测试报告通过邮件发出去——上(详解)

    简介 前边几篇,已经教小伙伴们掌握了如何生成HTML的测试报告,那么生成测试报告,我们也不能放在那里不管了,这样即使你报告在漂亮,领导也看不到.因此如果想向领导汇报工作,不仅需要提供更直观的测试报告. ...

  3. Hash的应用2

    代码: #include <stdio.h> #define OFFSET 500000//偏移量 ];//记录每个数是否出现,出现为1,不出现为0 int main(){ int n,m ...

  4. Spring Boot 邮件发送的 5 种姿势!

    邮件发送其实是一个非常常见的需求,用户注册,找回密码等地方,都会用到,使用 JavaSE 代码发送邮件,步骤还是挺繁琐的,Spring Boot 中对于邮件发送,提供了相关的自动化配置类,使得邮件发送 ...

  5. BZOJ 2039人员雇佣

    这道题教会我们一个道理靠谁也不如靠自己. 当时学长已经讲了,然而一脸懵逼,好吧,上网搜题解,二脸懵逼,于是自己动手,丰衣足食.自己推! 首先就是建模了,这道题谁与谁之间建模已经十分明了,超级源点,超级 ...

  6. BI之路学习笔记2--SSIS/ETL设计练习三:《DB->定期生成excel表》

    上次笔记记到,用sql任务给参数赋值,映射到变量,然后把数据流任务放到序列容器中进行执行,可以定期生成excel, 现在的问题是: 在EXCEL目标编辑过程中,必须选定某一个特定的excel目标,这样 ...

  7. 1.svn 彻底clear时,注意代码备份 2.借助vc助手加头文件

    1.svn 彻底clear时,注意代码备份 2.不小心彻底clear可以在回收站找到 3.借助vc助手加头文件

  8. Excel催化剂开源第39波-json字符串解释的超能类库

    对一般VBA开发群体来说,处理json.xml结构的数据源,在VB6的世界里,是一件非常不容易的事情,隐约记得当年自己从哪里找到了一个使用字典实现的json解释的函数,实在非常稀有. 在.Net的世界 ...

  9. 基于TCP协议的套接字编程

    06.26自我总结 1.关于Socket Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口.在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在 ...

  10. 基于SpringBoot+Redis的Session共享与单点登录

    title: 基于SpringBoot+Redis的Session共享与单点登录 date: 2019-07-23 02:55:52 categories: 架构 author: mrzhou tag ...