找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
楼主: 523066680

[原创代码] [造轮子]Perl脚本金额数字转中文大写

[复制链接]
 楼主| 发表于 2014-9-16 08:58:19 | 显示全部楼层
本帖最后由 523066680 于 2014-9-16 08:59 编辑

稍微做了改进
  1. use IO::Handle;
  2. use utf8;
  3. use Encode;
  4. STDOUT->autoflush(1);
  5. STDERR->autoflush(1);
  6. binmode(STDOUT, ":encoding(gbk)");

  7. our @unit_f = ("", "角");            #分省略,最后补上
  8. our @part = ("", "萬", "亿");        #元省略,最后补上
  9. our @unit = ("", "拾", "佰", "仟");  #同上
  10. our @cnum = qw/零 壹 贰 叁 肆 伍 陆 柒 捌 玖 拾/;

  11. foreach (
  12.     1.01,
  13.     900000000,
  14.     0.0,
  15.     7.2,
  16.     12300100.12,
  17.     101010101
  18. ) {
  19.     printf &main($_) . "\n";
  20. }
  21. <STDIN>;

  22. sub main {
  23.     my $inp = shift;
  24.     my ($str, $sect) = ("", "");
  25.     my ($ni, $nf, $i) = ("", "", undef);

  26.     return "零元" if ($inp == 0);

  27.     #整数部分和小数部分
  28.     ($ni, $nf) = split(/\./, sprintf("%.2f", $inp));

  29.     #处理整数部分
  30.     $i = 0;
  31.     while ($ni ne "") {
  32.         $ni=~s/(\d{0,4})$//;       #每四位数为一段进行截取
  33.         $sect = &func($1, \@unit);
  34.                                    # 如果某段大写返回为空(0000),则缩略
  35.                                    # 例如壹亿,而不是壹亿萬
  36.         if ($sect ne "") {
  37.             $str = $sect . $part[$i] . $str;      
  38.         }
  39.         $i++;
  40.     }
  41.     $str .="元" if ($str ne "");

  42.     #处理角和分
  43.     $sect = &func($nf, \@unit_f);
  44.     if ($sect ne "") {
  45.         $str = $str . $sect;
  46.         $str = $str ."分" unless ($sect=~/角$/);
  47.     }

  48.     return $str;
  49. }

  50. sub func {
  51.     our @cnum;
  52.     my ($num, $unit) = (shift, shift);
  53.     my @ints = reverse( split("", $num) );  #反转成 (个,十,佰,仟)
  54.     my $prev = 1;
  55.     my $begin = 0;
  56.     my $i;
  57.     my $str = "";

  58.     #略过低位连续出现的零
  59.     #例如,一百零拾零元简写为:一百元
  60.     while (
  61.         defined $ints[$begin]
  62.             and
  63.         $ints[$begin] == 0
  64.     ) {
  65.         $begin++;
  66.     }

  67.     foreach $i ($begin .. $#ints) {
  68.         if (
  69.             $ints[$i] == 0
  70.         ) {
  71.             if ($prev != 0) {
  72.                 $str = $cnum[$ints[$i]] . $str;   #零
  73.                 $prev = 0;
  74.             }
  75.             next;
  76.         }
  77.         $prev = $ints[$i];
  78.         $str = $cnum[$ints[$i]] . $unit->[$i] . $str;
  79.     }
  80.     return $str;
  81. }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-17 03:09 , Processed in 0.024013 second(s), 7 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表