[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖
本帖最后由 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. }
复制代码

TOP

返回列表