Como analisar o arquivo do Excel em Javascript / HTML5

136

Eu sou capaz de ler o arquivo Excel via, FileReadermas ele gera texto, além de caracteres estranhos. Preciso ler o xlsarquivo em linhas, ler dados em todas as colunas e convertê-los em JSON.

Como ler o arquivo xls linha por linha?

ducktyped
fonte
1
possível duplicação de Como ler o conteúdo de um arquivo excel no lado do cliente?
Algum programador
1
@JoachimPileborg: isso não responde à pergunta. Eu preciso ler o arquivo excel linha por linha. Embora eu possa lê-lo usando o FileReader (HTML5), mas ainda não consigo navegar pelas linhas.
ducktyped

Respostas:

104

A função Abaixo converte os dados da planilha do Excel (formato XLSX) em JSON. você pode adicionar promessa à função.

<script src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.8.0/jszip.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.8.0/xlsx.js"></script>
<script>
var ExcelToJSON = function() {

  this.parseExcel = function(file) {
    var reader = new FileReader();

    reader.onload = function(e) {
      var data = e.target.result;
      var workbook = XLSX.read(data, {
        type: 'binary'
      });

      workbook.SheetNames.forEach(function(sheetName) {
        // Here is your object
        var XL_row_object = XLSX.utils.sheet_to_row_object_array(workbook.Sheets[sheetName]);
        var json_object = JSON.stringify(XL_row_object);
        console.log(json_object);

      })

    };

    reader.onerror = function(ex) {
      console.log(ex);
    };

    reader.readAsBinaryString(file);
  };
};
</script>

Abaixo do post tem o código para o formato XLS Excel para JSON código javascript?

Peru
fonte
1
falha para arquivos maiores do excel no chrome, alguma boa solução para isso?
Zed
Posso saber o tamanho do seu arquivo?
Peru
6
e.target.result () deve ser e.target.result ver developer.mozilla.org/en-US/docs/Web/API/FileReader/onload
user227353
3
Para mim, eu tive que declarar o jszip.jsscript antes xlsx.js.
Florin Vîrdol 10/08/19
1
Como atribuir json_object à variável pública e acessá-la fora do loop for?
Shardul 8/08/19
109

Pergunta antiga, mas devo observar que a tarefa geral de analisar arquivos XLS do javascript é tediosa e difícil, mas não impossível.

Eu tenho analisadores básicos implementados em JS puro:

Ambas as páginas são analisadores XLS / XLSX controlados por API de arquivos HTML5 (você pode arrastar e soltar seu arquivo e ele imprimirá os dados nas células em uma lista separada por vírgulas). Você também pode gerar objetos JSON (assumindo que a primeira linha seja uma linha de cabeçalho).

O conjunto de testes http://oss.sheetjs.com/ mostra uma versão que usa o XHR para obter e analisar arquivos.

SheetJS
fonte
4
Se você pudesse adicionar algum código de amostra à resposta, isso o tornaria muito melhor (também adicione um aviso de responsabilidade se você for o líder das bibliotecas).
acdcjunior
3
Eu publiquei um blog sobre isso psjinx.com/programming/2014/01/04/… :)
pankaj28843
podemos pular algumas linhas e colunas principais do xlsx com JS-XLSX?
Mayank
19

Faça o upload de um excel fileaqui e você poderá obter os dados em JSONformato em console:

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.8.0/jszip.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.8.0/xlsx.js"></script>
<script>
    var ExcelToJSON = function() {

      this.parseExcel = function(file) {
        var reader = new FileReader();

        reader.onload = function(e) {
          var data = e.target.result;
          var workbook = XLSX.read(data, {
            type: 'binary'
          });
          workbook.SheetNames.forEach(function(sheetName) {
            // Here is your object
            var XL_row_object = XLSX.utils.sheet_to_row_object_array(workbook.Sheets[sheetName]);
            var json_object = JSON.stringify(XL_row_object);
            console.log(JSON.parse(json_object));
            jQuery( '#xlx_json' ).val( json_object );
          })
        };

        reader.onerror = function(ex) {
          console.log(ex);
        };

        reader.readAsBinaryString(file);
      };
  };

  function handleFileSelect(evt) {
    
    var files = evt.target.files; // FileList object
    var xl2json = new ExcelToJSON();
    xl2json.parseExcel(files[0]);
  }


 
</script>

<form enctype="multipart/form-data">
    <input id="upload" type=file  name="files[]">
</form>

    <textarea class="form-control" rows=35 cols=120 id="xlx_json"></textarea>

    <script>
        document.getElementById('upload').addEventListener('change', handleFileSelect, false);

    </script>

Esta é uma combinação das seguintes Stackoverflowpostagens:

  1. https://stackoverflow.com/a/37083658/4742733
  2. https://stackoverflow.com/a/39515846/4742733

Boa sorte...

Akash
fonte
14

Esse código pode ajudá-lo
Na maioria das vezes, o jszip.js não está funcionando, portanto, inclua xlsx.full.min.js no seu código js.

Código HTML

 <input type="file" id="file" ng-model="csvFile"  
    onchange="angular.element(this).scope().ExcelExport(event)"/>

Javascript

<script src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.8.0/xlsx.js">
</script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.8.0/jszip.js">
</script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.10.8/xlsx.full.min.js">
</script>

$scope.ExcelExport= function (event) {


    var input = event.target;
    var reader = new FileReader();
    reader.onload = function(){
        var fileData = reader.result;
        var wb = XLSX.read(fileData, {type : 'binary'});

        wb.SheetNames.forEach(function(sheetName){
        var rowObj =XLSX.utils.sheet_to_row_object_array(wb.Sheets[sheetName]);
        var jsonObj = JSON.stringify(rowObj);
        console.log(jsonObj)
        })
    };
    reader.readAsBinaryString(input.files[0]);
    };
afzalriz304
fonte
Que tal se eu quero fazer upload de imagens, bem como em folha de excel
Mayur Agarwal
9

Se você desejar a maneira mais simples e minuciosa de ler um arquivo * .xlsx em um navegador, esta biblioteca poderá:

https://catamphetamine.github.io/read-excel-file/

<input type="file" id="input" />
import readXlsxFile from 'read-excel-file'

const input = document.getElementById('input')

input.addEventListener('change', () => {
  readXlsxFile(input.files[0]).then((data) => {
    // `data` is an array of rows
    // each row being an array of cells.
  })
})

No exemplo acima dataestão os dados brutos da string. Ele pode ser analisado no JSON com um esquema estrito, passando o schemaargumento. Veja os documentos da API para obter um exemplo disso.

Documentos da API: http://npmjs.com/package/read-excel-file

catanfetamina
fonte
4

Obrigado pela resposta acima, acho que o escopo (de respostas) está completo, mas gostaria de adicionar uma "maneira de reagir" para quem usa o react.

Crie um arquivo chamado importData.js:

import React, {Component} from 'react';
import XLSX from 'xlsx';
export default class ImportData extends Component{
    constructor(props){
        super(props);
        this.state={
            excelData:{}
        }
    }
    excelToJson(reader){
        var fileData = reader.result;
        var wb = XLSX.read(fileData, {type : 'binary'});
        var data = {};
        wb.SheetNames.forEach(function(sheetName){
             var rowObj =XLSX.utils.sheet_to_row_object_array(wb.Sheets[sheetName]);
             var rowString = JSON.stringify(rowObj);
             data[sheetName] = rowString;
        });
        this.setState({excelData: data});
    }
    loadFileXLSX(event){
        var input = event.target;
        var reader = new FileReader();
        reader.onload = this.excelToJson.bind(this,reader);
        reader.readAsBinaryString(input.files[0]);
    }
    render(){
        return (
            <input type="file" onChange={this.loadFileXLSX.bind(this)}/>
        );
    }
}

Então você pode usar o componente no método de renderização como:

import ImportData from './importData.js';
import React, {Component} from 'react';
class ParentComponent extends Component{
    render(){
        return (<importData/>);
    }
}

<ImportData/>definir os dados para seu próprio estado, você poderá acessar os dados do Excel no "componente pai", seguindo este procedimento :

Os portões de Sião
fonte
Eu acho que a tag na declaração de retorno deve ser em <ImportData/>vez de <importData/>. Eu sou bastante novo no React, mas acredito que os nomes dos componentes são sempre capitalizados. De qualquer forma, esse é o nome usado ao importar no exemplo.
rhaben 8/07
3

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.8.0/jszip.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.8.0/xlsx.js"></script>
<script>
    var ExcelToJSON = function() {

      this.parseExcel = function(file) {
        var reader = new FileReader();

        reader.onload = function(e) {
          var data = e.target.result;
          var workbook = XLSX.read(data, {
            type: 'binary'
          });
          workbook.SheetNames.forEach(function(sheetName) {
            // Here is your object
            var XL_row_object = XLSX.utils.sheet_to_row_object_array(workbook.Sheets[sheetName]);
            var json_object = JSON.stringify(XL_row_object);
            console.log(JSON.parse(json_object));
            jQuery( '#xlx_json' ).val( json_object );
          })
        };

        reader.onerror = function(ex) {
          console.log(ex);
        };

        reader.readAsBinaryString(file);
      };
  };

  function handleFileSelect(evt) {
    
    var files = evt.target.files; // FileList object
    var xl2json = new ExcelToJSON();
    xl2json.parseExcel(files[0]);
  }


 
</script>

<form enctype="multipart/form-data">
    <input id="upload" type=file  name="files[]">
</form>

    <textarea class="form-control" rows=35 cols=120 id="xlx_json"></textarea>

    <script>
        document.getElementById('upload').addEventListener('change', handleFileSelect, false);

    </script>

amin
fonte
0

Se você já se perguntou como ler um arquivo do servidor, esse código pode ser útil.

Restrições:

  1. O arquivo deve estar no servidor (Local / Remoto).
  2. Você precisará configurar os cabeçalhos ou o plug-in CORS do Google.

<Head>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
    <script lang="javascript" src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.12.4/xlsx.core.min.js"></script>
</head>

<body>
    <script>
    /* set up XMLHttpRequest */


    // replace it with your file path in local server
    var url = "http://localhost/test.xlsx";

    var oReq = new XMLHttpRequest();
    oReq.open("GET", url, true);
    oReq.responseType = "arraybuffer";

    oReq.onload = function(e) {
        var arraybuffer = oReq.response;

        /* convert data to binary string */
        var data = new Uint8Array(arraybuffer);

        var arr = new Array();
        for (var i = 0; i != data.length; ++i) {
            arr[i] = String.fromCharCode(data[i]);
        }

        var bstr = arr.join("");

        var cfb = XLSX.read(bstr, { type: 'binary' });

        cfb.SheetNames.forEach(function(sheetName, index) {

            // Obtain The Current Row As CSV
            var fieldsObjs = XLS.utils.sheet_to_json(cfb.Sheets[sheetName]);

            fieldsObjs.map(function(field) {
                $("#my_file_output").append('<input type="checkbox" value="' + field.Fields + '">' + field.Fields + '<br>');
            });

        });
    }

    oReq.send();
    </script>
</body>
<div id="my_file_output">
</div>

</html>
Vijay Reddy
fonte
0

inclua o xslx.js, xlsx.full.min.js, jszip.js

inclua um manipulador de eventos onchange na entrada do arquivo

function showDataExcel(event)
{
            var file = event.target.files[0];
            var reader = new FileReader();
            var excelData = [];
            reader.onload = function (event) {
                var data = event.target.result;
                var workbook = XLSX.read(data, {
                    type: 'binary'
                });

                workbook.SheetNames.forEach(function (sheetName) {
                    // Here is your object
                    var XL_row_object = XLSX.utils.sheet_to_row_object_array(workbook.Sheets[sheetName]);

                    for (var i = 0; i < XL_row_object.length; i++)
                    {
                        excelData.push(XL_row_object[i]["your column name"]);

                    }

                    var json_object = JSON.stringify(XL_row_object);
                    console.log(json_object);
                    alert(excelData);
                })

            };

            reader.onerror = function (ex) {
                console.log(ex);
            };

            reader.readAsBinaryString(file);

}
vsnahar
fonte
-4

XLS é um formato proprietário binário usado pela Microsoft. A análise do XLS com idiomas do servidor é muito difícil sem o uso de uma biblioteca específica ou a Interoperabilidade do Office. Fazer isso com javascript é uma missão impossível. Graças à API de arquivos HTML5, você pode ler seu conteúdo binário, mas para analisá-lo e interpretá-lo, você precisará mergulhar nas especificações do formato XLS . A partir do Office 2007, a Microsoft adotou os formatos de arquivo Open XML ( xslxpara Excel), que é um padrão.

Darin Dimitrov
fonte
@ Ducktyped, não estou ciente nem vi qualquer código javascript que lê um arquivo binário do Excel.
precisa
13
Missão Impossível? Eu duvido. Se pudermos executar o kernel do Linux em javascript do lado do cliente, será possível analisar um arquivo binário do Excel. É que ninguém que eu saiba ainda o fez.
JP Richardson
Aqui está a documentação para curioso da estrutura ms xls msdn.microsoft.com/en-us/library/office/...
djra
-5

var excel = novo ActiveXObject ("Excel.Application"); var book = excel.Workbooks.Open (your_full_file_name_here.xls); var plan = book.Sheets.Item (1); valor var = sheet.Range ("A1");

quando você tem a folha. Você pode usar as funções do VBA como no Excel.

i100
fonte
6
isso só funciona com o "nosso querido amigo" IE. E eu preciso usar HTML5. Eu só preciso navegar conteúdo de texto real linha por linha.
ducktyped