perl excel檔案和txt轉換

來源:互聯網
上載者:User
excel2txt.pl

#!/usr/bin/perl

use strict;

use Spreadsheet::ParseExcel;

my $oExcel = new Spreadsheet::ParseExcel;

die "Usage : \n\tperl $0 <xls> > xls.txt\n\n" unless @ARGV;

my $oBook = $oExcel->Parse($ARGV[0]);
my($iR, $iC, $oWkS, $oWkC);

for(my $iSheet=0; $iSheet < $oBook->{SheetCount} ; $iSheet++){
        $oWkS = $oBook->{Worksheet}[$iSheet];
        for(my $iR = $oWkS->{MinRow} ; defined $oWkS->{MaxRow} && $iR <= $oWkS->{MaxRow} ; $iR++) {
                for(my $iC = $oWkS->{MinCol} ; defined $oWkS->{MaxCol} && $iC <= $oWkS->{MaxCol} ; $iC++)  {
                        $oWkC = $oWkS->{Cells}[$iR][$iC];
                        print $oWkC->Value,"\t" if($oWkC);
                }
                print "\n";
        }
}

輸入為xls格式,叢集下可用。

txt2excel.pl

#!/usr/bin/perl
use strict;
use Encode qw(decode);
use Spreadsheet::WriteExcel;
my $workbook = Spreadsheet::WriteExcel->new("$ARGV[0].xls");
my $worksheet = $workbook->add_worksheet();
# Row and column are zero indexed
my $row = 0;
open IN,$ARGV[0] or die $!;
while(<IN>){
        chomp;my @s = split;
        my $col = 0;
        foreach my $token(@s){
                $worksheet->write_string($row,$col,decode('gb2312',$token));
                $col++;
        }
        $row++;
}
close IN;

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.