postgresql基于plpython实现数字转RMB中文

2019-11-05  本文已影响0人  Hmcf
安装扩展
创建函数
create or replace function digit_to_rmb(digital numeric)returns text as $$
global digital
str_digital = str(digital)
chinese = {'1': '壹', '2': '贰', '3': '叁', '4': '肆', '5': '伍',
           '6': '陆', '7': '柒', '8': '捌', '9': '玖', '0': '零'}
chinese2 = ['拾', '佰', '仟', '万', '厘', '分', '角']
jiao = ''
bs = str_digital.split('.')
yuan = bs[0]
if len(bs) > 1:
    jiao = bs[1]
r_yuan = [i for i in reversed(yuan)]
count = 0
for i in range(len(yuan)):
    if i == 0:
        r_yuan[i] += '圆'
        continue
    r_yuan[i] += chinese2[count]
    count += 1
    if count == 4:
        count = 0
        chinese2[3] = '亿'

s_jiao = [i for i in jiao][:3]

j_count = -1
for i in range(len(s_jiao)):
    s_jiao[i] += chinese2[j_count]
    j_count -= 1
last = [i for i in reversed(r_yuan)] + s_jiao
last_str = ''.join(last)

for i in range(len(last_str)):
    digital = last_str[i]
    if digital in chinese:
        last_str = last_str.replace(digital, chinese[digital])

return last_str

$$ language plpython2u
可能存在的问题
issue.png
解决方法
上一篇 下一篇

猜你喜欢

热点阅读