阿拉伯数字转简体中文数字

这是一个可以再进一步优化的存储过程,借鉴了网上流传的金额转换代码。


  --将阿拉伯数字转为中文小数
  function araNum2CnDec(p_num number) return varchar2 is
    sdec   varchar2(50);
    i      pls_integer;
    len    pls_integer;
    sch    varchar2(20) := '〇一二三四五六七八九';
    scndec varchar2(100);
    num    pls_integer;
  begin
    sdec := to_char(p_num);
    if instr(sdec, '.') = 0 then
      return null;
    else
      sdec := substr(sdec, instr(sdec, '.') + 1);
      len  := length(sdec);
      for i in 1 .. len loop
        num    := to_number(substr(sdec, i, 1));
        scndec := scndec || substr(sch, num + 1, 1);
      end loop;
      return '〇点' || scndec;
    end if;
  end;

 

  --将阿拉伯数字转为中文整数
  function araNum2CnInt(p_num number) RETURN VARCHAR2 IS
    i      pls_integer;
    sint   varchar2(50) := ltrim(to_char(abs(p_num),
                                         '99999999999999999999999999999990'));
    len    pls_integer := length(sint);
    sch    varchar2(20) := '〇一二三四五六七八九';
    sjin   varchar2(100) := '十百千万十百千亿十百千万十百千万十百千万十百千万十百千万十百千万';
    scnint varchar2(100) := '';
    num    pls_integer;
    s_num  pls_integer := 0; --'0'起始位置  
    e_num  pls_integer := 0; --'0'结束位置  
  begin
    for i in 1 .. len loop
      num := to_number(substr(sint, i, 1));
      if num <> 0 then
        --非'0'时处理:  
        if s_num = 0 then
          --前面无零时处理
          if i = len then
            --最后一位
            scnint := scnint || substr(sch, num + 1, 1);
          else
            scnint := scnint || substr(sch, num + 1, 1) ||
                      substr(sjin, len - i, 1); --前面字符非'0', 正常联接...
          end if;
        else
          --前面有零时处理
          scnint := scnint || case
                      when s_num < 8 and s_num >= 5 and e_num <= 5 then --前面只有一个'0'  
                       '万'
                      when s_num < 12 and s_num >= 8 and e_num <= 8 then --否则(多个'0'处理)  
                       '亿'
                      when s_num >= 12 and e_num < 8 then
                       trim(lpad('  ', ((s_num - 12) / 4 + 1) * 2, '万')) || '亿'
                      when s_num >= 12 and e_num >= 8 then
                       trim(lpad('  ', ((s_num - e_num) / 4 + 1) * 2, '万'))
                    end || case
                      when s_num - e_num >= 0 then
                       '〇'
                    end;
          if i = len then
            scnint := scnint || substr(sch, num + 1, 1);
          else
            scnint := scnint || substr(sch, num + 1, 1) ||
                      substr(sjin, len - i, 1);
          end if;
        end if;
        s_num := 0; --重置为前面无零
        e_num := 0;
      else
        --遇零时处理
        if s_num = 0 then
          --当s_num = 0时'0'串起始,  
          s_num := len - i + 1; --记录开始  
          e_num := s_num; --结束位置。  
        else
          e_num := len - i + 1; --新的结束位置。  
        end if;
      end if;
   
    end loop;
    --一直0到结尾的情况
    if s_num <> 0 then
      scnint := scnint || case
                  when s_num = len then
                   '〇'
                  when s_num < 8 and s_num >= 5 then
                   '万'
                  when s_num > 8 then
                   trim(lpad('  ', trunc((s_num - 9) / 4+1) * 2, '万')) || '亿'
                end;
    end if;
    --处理"一十"开头的数字为"十"的情况
    if instr(scnint, '一十') = 1 then
      scnint := substr(scnint, 2);
    end if;
    if p_num < 0 then
      scnint := '负' || scnint;
    end if;
    RETURN scnint;
  end;


  --将阿拉伯数字转为中文数字
  function to_cnNumber(p_num number) return string is
  begin
    return araNum2CnInt(p_num) || substr(araNum2CnDec(p_num), 2);
  end;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是阿拉伯数字转换为中文大写数字的代码: ```python def num2cn(num): # 中文大写数字 cn_num = { '0': '零', '1': '壹', '2': '贰', '3': '叁', '4': '肆', '5': '伍', '6': '陆', '7': '柒', '8': '捌', '9': '玖' } # 中文数字单位 cn_unit = ['', '拾', '佰', '仟', '万', '亿'] # 将数字转换为字符串并反 num_str = str(num)[::-1] # 记录是否出现过非零数字 has_value = False # 记录是否需要添加单位 need_unit = False # 记录上一个数字是否为零 prev_zero = False # 中文大写数字字符串 cn_str = '' # 遍历数字字符串 for i in range(len(num_str)): # 当前数字 n = num_str[i] # 当前单位 unit = cn_unit[i] # 如果当前数字为零 if n == '0': # 如果之前没有出现过非零数字,不需要将零添加到字符串中 if not has_value: continue # 如果之前出现过非零数字,并且上一个数字不是零,需要将零添加到字符串中 elif not prev_zero: cn_str += cn_num[n] prev_zero = True # 如果当前数字不为零 else: # 添加单位 if need_unit: cn_str += unit # 添加数字 cn_str += cn_num[n] # 标记出现过非零数字 has_value = True # 标记当前数字不是零 prev_zero = False # 标记需要添加单位 need_unit = True # 如果当前数字已经是最后一位,并且需要添加单位,添加“元”单位 if i == len(num_str) - 1 and need_unit: cn_str += '元' # 将字符串反并返回 return cn_str[::-1] ``` 使用示例: ```python num = 123456789 cn_num = num2cn(num) print(cn_num) # 输出:壹亿贰仟叁佰肆拾伍万陆仟柒佰捌十九元 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值