AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / ubuntu / Perguntas / 1080394
Accepted
Bruni
Bruni
Asked: 2018-10-03 11:07:13 +0800 CST2018-10-03 11:07:13 +0800 CST 2018-10-03 11:07:13 +0800 CST

Como combinar vários arquivos CSV em um arquivo ods na linha de comando. Uma folha por arquivo original

  • 772

Como combinar vários arquivos CSV em um arquivo ods, uma folha por arquivo . Tenho dez arquivos CSV e gostaria de combiná-los em um arquivo ods composto por dez folhas, uma por CSV original. Isso deve ser feito na linha de comando.

bash csv
  • 1 1 respostas
  • 1891 Views

1 respostas

  • Voted
  1. Best Answer
    glenn jackman
    2018-10-03T12:58:26+08:002018-10-03T12:58:26+08:00

    Com Perl:

    #!/usr/bin/env perl
    use strict;
    use warnings;
    use autodie;
    # CPAN modules required:
    use Spreadsheet::Write;
    use Text::CSV;
    
    my $xlsx_file = shift @ARGV;
    $xlsx_file .= ".xlsx" unless $xlsx_file =~ /\.xlsx$/;
    my $xlsx = Spreadsheet::Write->new(file => $xlsx_file);
    my $csv = Text::CSV->new({binary => 1});
    
    for my $csv_file (@ARGV) {
        my @rows = ();
        open my $fh, "<:encoding(utf8)", $csv_file;
        while (my $row = $csv->getline($fh)) {
            push @rows, $row;
        }
        $csv->eof or $csv->error_diag();
        close $fh;  
    
        (my $sheet_name = $csv_file) =~ s/\.[^.]+$//;   # strip extension
        $xlsx->addsheet($sheet_name);
        $xlsx->addrows(@rows);
    }
    $xlsx->close();
    

    E use como:

    /path/to/create_xlsx.pl file.xlsx *.csv
    

    Se perl não é sua praia, um pouco de googling revela:

    • python: https://openpyxl.readthedocs.io/en/stable/
    • ruby: https://stackoverflow.com/questions/4644341/which-gem-support-import-export-to-xlsx-file-in-ruby
    • 2

relate perguntas

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Existe um comando para listar todos os usuários? Também para adicionar, excluir, modificar usuários, no terminal?

    • 9 respostas
  • Marko Smith

    Como excluir um diretório não vazio no Terminal?

    • 4 respostas
  • Marko Smith

    Como descompactar um arquivo zip do Terminal?

    • 9 respostas
  • Marko Smith

    Como instalo um arquivo .deb por meio da linha de comando?

    • 11 respostas
  • Marko Smith

    Como instalo um arquivo .tar.gz (ou .tar.bz2)?

    • 14 respostas
  • Marko Smith

    Como listar todos os pacotes instalados

    • 24 respostas
  • Martin Hope
    Flimm Como posso usar o docker sem sudo? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    led-Zepp Como faço para salvar a saída do terminal em um arquivo? 2014-02-15 11:49:07 +0800 CST
  • Martin Hope
    ubuntu-nerd Como descompactar um arquivo zip do Terminal? 2011-12-11 20:37:54 +0800 CST
  • Martin Hope
    TheXed Como instalo um arquivo .deb por meio da linha de comando? 2011-05-07 09:40:28 +0800 CST
  • Martin Hope
    Ivan Como listar todos os pacotes instalados 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    David Barry Como determino o tamanho total de um diretório (pasta) na linha de comando? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher "Os seguintes pacotes foram retidos:" Por que e como resolvo isso? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford Como os PPAs podem ser removidos? 2010-07-30 01:09:42 +0800 CST

Hot tag

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve