JavaScript / HTML5でExcelファイルを解析する方法


136

私はExcelファイルを介して読むことができますFileReaderが、それはそれとともにテキストと変な文字を出力します。xls行ごとにファイルを読み取り、すべての列のデータを読み取ってJSONに変換する必要があります。

行ごとにXLSファイルを読み取る方法は?



1
@JoachimPileborg:これは質問に答えません。行ごとにExcelファイルを読む必要があります。FileReader(HTML5)を使用して読み取ることはできますが、それでも行を参照することはできません。
ducktyped

回答:


104

以下の関数は、Excelシート(XLSX形式)データをJSONに変換します。関数にプロミスを追加できます。

<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>

以下の投稿には、XLS形式のExcelからJSONのJavaScriptコードのコードがありますか?


1
それはクロームの大きなExcelファイルでクラッシュします、そのための良い解決策はありますか?
2016年

ファイルの大きさを教えてください。
ペルー

6
e.target.result()e.target.resultを参照する必要がありますdeveloper.mozilla.org/en-US/docs/Web/API/FileReader/onload
user227353

3
私にとっては、jszip.js以前にスクリプトを宣言する必要がありましたxlsx.js
FlorinVîrdol18年

1
json_objectをパブリック変数に割り当てて、forループの外でそれにアクセスするにはどうすればよいですか?
Shardul、

109

古い質問ですが、JavaScriptからXLSファイルを解析する一般的なタスクは退屈で困難ですが、不可能ではないことに注意してください。

純粋なJSで実装された基本的なパーサーがあります。

どちらのページもHTML5ファイルAPI駆動のXLS / XLSXパーサーです(ファイルをドラッグアンドドロップすると、セル内のデータがカンマ区切りのリストで印刷されます)。JSONオブジェクトを生成することもできます(最初の行がヘッダー行であると想定)。

テストスイートhttp://oss.sheetjs.com/は、XHRを使用してファイルを取得および解析するバージョンを示しています。


4
回答にいくつかのサンプルコードを追加できれば、はるかに良くなります(ライブラリのリーダーである場合は、ダイアクレームも追加します)。
acdcjunior 2013年

3
私はこのpsjinx.com/programming/2014/01/04/…についてブログを書いた :)
pankaj28843 14年

JS-XLSXでxlsxの上位の行と列をいくつかスキップできますか?
2015年

19

excel fileここにアップロードすると、次のJSON形式でデータを取得できます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>

これは、次のStackoverflow投稿の組み合わせです。

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

幸運を...


14

このコード
は、ほとんどの場合jszip.jsが機能しないために役立ちます。jsコードにxlsx.full.min.jsを含めます。

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]);
    };

Excelシートで画像もアップロードしたい場合はどうですか
Mayur Agarwal

9

ブラウザーで* .xlsxファイルを読み取る最も簡単で小さな方法が必要な場合、このライブラリは次のようにすることができます。

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.
  })
})

上記の例でdataは生の文字列データです。schema引数を渡すことで、厳密なスキーマを持つJSONに解析できます。その例については、APIドキュメントを参照してください。

APIドキュメント:http : //npmjs.com/package/read-excel-file


4

上記の回答をありがとう、私は(回答の)範囲は完成したと思いますが、reactを使用する人のための「反応方法」を追加したいと思います。

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)}/>
        );
    }
}

次に、コンポーネントをrenderメソッドで次のように使用できます。

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

<ImportData/>あなたは以下のことで、「親コンポーネント」でExcelデータにアクセスすることができ、自身の状態にデータを設定しますこれを


私は、return文でタグがされるべきだと思う<ImportData/>の代わりに<importData/>。私はReactにかなり慣れていませんが、コンポーネント名は常に大文字で表記されていると思います。いずれの場合も、例でインポートするときに使用される名前です。
ラーベン

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>


0

サーバーからファイルを読み取る方法について疑問がある場合は、このコードが役立つ可能性があります。

制限:

  1. ファイルはサーバー(ローカル/リモート)にある必要があります。
  2. ヘッダーを設定するか、CORS 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>

0

xslx.js、xlsx.full.min.js、jszip.jsを含めます

onchangeイベントハンドラーをファイル入力に追加する

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);

}

-4

XLSは、マイクロソフトが使用する独自のバイナリ形式です。特定のライブラリやOffice Interopを使用しないと、サーバー側の言語でXLSを解析することは非常に困難です。javascriptでこれを行うことは、ミッション不可能です。HTML5ファイルAPIのおかげで、そのバイナリコンテンツを読み取ることができますが、それを解析して解釈するには、XLS形式の仕様に飛び込む必要があります。MicrosoftはOffice 2007以降、標準であるOpen XMLファイル形式(xslxExcel用)を採用しました。


@ducktyped、バイナリのExcelファイルを読み取るjavascriptコードを知りません。
Darin Dimitrov

13
ミッション・インポッシブル?疑わしい。Linuxカーネルをクライアント側のJavaScriptで実行できれば、バイナリのExcelファイルを解析できるはずです。それは、私の知る限り誰もまだそれをしていないというだけです。
JPリチャードソン

ここでは、MS XLS構造の好奇心のドキュメントであるmsdn.microsoft.com/en-us/library/office/...
DJRA

-5

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

あなたがシートを持っているとき。Excelと同じようにVBA関数を使用できます。


6
これは「私たちの親愛なる友人」IEでのみ機能します。そして、私はHTML5を使用する必要があります。行ごとに実際のテキストコンテンツを参照するだけです。
ducktyped
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.