免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 5058 | 回复: 18
打印 上一主题 下一主题

将文本格式转换成表格形式(使用等宽字体显示) [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-03-31 15:46 |只看该作者 |倒序浏览
30可用积分
本帖最后由 Perlvim 于 2013-03-31 15:49 编辑

一个由二个空格以上分隔的列
colname1   colname2   colname3
str1       str2      str3
str4       str5      str6

转换成:

------------------------------
colname1 | colname2 | colname3
------------------------------
str1        | str2     | str3
------------------------------
str4        | str5     | str6
------------------------------


或者其中有一个单元格为空

colname1   colname2   colname3
str1                  str3
str4       str5       str6

转换成:

------------------------------
colname1 | colname2 | colname3
------------------------------
str1        |                | str3
------------------------------
str4        | str5         | str6
------------------------------

其中一个单元格有换行
colname1   colname2   colname3
str1       str2       str3 str3
                      str3
str4       str5       str6

-------------------------------
colname1 | colname2 | colname3
-----------------------------
str1        | str2           | str3 str3
              |                  | str3
-----------------------------
str4        | str5           | str6
-----------------------------

最佳答案

查看完整内容

回复 12# Perlvim

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
2 [报告]
发表于 2013-03-31 15:47 |只看该作者
  1. #!/usr/bin/env perl

  2. use strict;
  3. use Data::Dumper;
  4. my %data_v;
  5. my $max_len;
  6. my ($line,$col);
  7. while(<DATA>){
  8.         chomp;
  9.         $line++;
  10.         $col = 0;
  11.         map{
  12.                 push @{$data_v{$line}},$_;
  13.                 $col++;
  14.                 $max_len = length($_) if $max_len <= length($_);
  15.         }split; # use your defined delimited character, like "\t", to separate the line;
  16. }

  17. my $ps = $max_len * $col + ($col - 1)*3;
  18. foreach my $x (1..$line){
  19.                 print "|-" . '-' x $ps . "|\n| ";
  20.                 print join " | ", map{$max_len == length($_) ? $_ : $_ . ' ' x ($max_len - length($_))}@{$data_v{$x}};
  21.                 print "|\n";
  22. }
  23. print "|-" . '-' x $ps . "|\n";
  24. __DATA__
  25. col1                 col2                  col3                         col4
  26. Abidjan      Banjul       Conakry        Harare
  27. Accra        Bissau       Dakar          Johannesburg
  28. Addis_Ababa  Blantyre     Dar_es_Salaam  Juba
  29. Algiers      Brazzaville  Djibouti       Kampala
复制代码
回复 12# Perlvim


   

论坛徽章:
7
戌狗
日期:2013-12-15 20:43:38技术图书徽章
日期:2014-03-05 01:33:12技术图书徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16赛季CBA联赛之青岛
日期:2016-03-17 20:36:13
3 [报告]
发表于 2013-03-31 17:03 |只看该作者
如何不一样?
  1. 其中一个单元格有换行
  2. colname1   colname2   colname3
  3. str1       str2       str3 str3
  4.                       str3
  5. str4       str5       str6
复制代码
  1. AAA      BBB      CCC
  2. a1        b1       c1c2
  3. empty   empty  c2
  4. a2        b2       c2
复制代码

论坛徽章:
0
4 [报告]
发表于 2013-03-31 18:26 |只看该作者
回复 2# rubyish
有换行,还是一个单元格,前两个都为空,就是单独的单元格了。


   

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
5 [报告]
发表于 2013-03-31 19:23 |只看该作者
这不是 format 干的事吗?不过我从来没学会啊,还有相关的那几个特殊变量

论坛徽章:
0
6 [报告]
发表于 2013-03-31 21:16 |只看该作者
回复 4# zhlong8

format 不是程序员做的事情,简直就是文员做的事情,比 word 还麻烦,根本没有程序的特性。

   

论坛徽章:
7
戌狗
日期:2013-12-15 20:43:38技术图书徽章
日期:2014-03-05 01:33:12技术图书徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16赛季CBA联赛之青岛
日期:2016-03-17 20:36:13
7 [报告]
发表于 2013-04-01 09:43 |只看该作者
本帖最后由 rubyish 于 2013-04-01 05:46 编辑

是 ma ?
  1. #!/usr/bin/perl
  2. sub table {
  3.     my %i = ( @_, @_ % 2 ? 0 : () );
  4.     my @dat = @{ $i{data} || shift };
  5.     my $p = $i{align} // 0;
  6.     my %T   = (
  7.         t => [ qw(┌ ┬ ┐) ],
  8.         m => [ qw(├ ┼ ┤) ],
  9.         b => [ qw(└ ┴ ┘) ],
  10.         h => '─', v => '│'
  11.     );
  12.     my $l = 0;
  13.     map $l < $_ && ( $l = $_ ), map length, map @$_, @dat;
  14.     my $e = scalar @{ $dat[0] };
  15.     my ( $ht, $hm, $hb ) = map {
  16.         $T{$_}[0] . join( $T{$_}[1], ( $T{h} x ( $l + 2 ) ) x $e ) . "$T{$_}[2]\n";
  17.     } qw/t m b/;
  18.     my $al = sub { map { my $s = $" x ( 1 + $l - length ); $p ? "$s$_ " : " $_$s" } @_ };
  19.     my $text = sub { $T{v} . join( $T{v}, $al->(@_) ) . "$T{v}\n" };
  20.     $ht . join( $hm, map $text->(@$_), @dat ) . $hb;
  21. }

  22. my @a = map [split], <DATA>;

  23. print table \@a;
  24. print table data => \@a, align => 1;
  25. print table data => \@a';

  26. __DATA__
  27. Abidjan      Banjul       Conakry        Harare
  28. Accra        Bissau       Dakar          Johannesburg
  29. Addis_Ababa  Blantyre     Dar_es_Salaam  Juba
  30. Algiers      Brazzaville  Djibouti       Kampala
复制代码

论坛徽章:
0
8 [报告]
发表于 2013-04-01 11:04 |只看该作者
其中有单元格和回车只能是肉眼判断啊? 那程序也无能为力呀

论坛徽章:
0
9 [报告]
发表于 2013-04-01 11:06 |只看该作者
回复 6# rubyish

呵呵,您写的代码永远这么高深莫测,我总是看不懂


   

论坛徽章:
0
10 [报告]
发表于 2013-04-01 11:10 |只看该作者
本帖最后由 Perlvim 于 2013-04-01 11:11 编辑

好好研究中。。
  1. ┌───────┬───────┬───────┬───────┐
  2. │ Abidjan      │ Banjul       │ Conakry      │ Harare       │
  3. ├───────┼───────┼───────┼───────┤
  4. │ Accra        │ Bissau       │ Dakar        │ Johannesburg │
  5. ├───────┼───────┼───────┼───────┤
  6. │ Addis_Ababa  │ Blantyre     │Dar_es_Salaam │ Juba         │
  7. ├───────┼───────┼───────┼───────┤
  8. │ Algiers      │ Brazzaville  │ Djibouti     │ Kampala      │
  9. └───────┴───────┴───────┴───────┘
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP