JavaScriptスプレッドシートライブラリ「SpreadJS(スプレッドJS)」では、さまざまなレイアウトの帳票が開発できる「レポートシート」機能を提供しています。レポートシートではExcelライクなデザイナで帳票のデザインができるほか、既存のExcel帳票を取り込んでの帳票開発も可能なので、Excel帳票からモダンなWeb帳票に移行したいという要件に最適なソリューションです。
今回はレポートシートを使用して既存のExcel帳票をモダンなWeb帳票に移行する方法をご紹介します。

移行元のExcel帳票
今回は以下のようなExcel帳票を移行します。帳票の中ではExcelの数式や関数などを使って集計も行っています。
Excel帳票の取り込み(テンプレートシートの作成)
デザイナの起動
まずは上記のExcel帳票のレイアウトを取り込んで、レポートシートの帳票レイアウトを定義するテンプレートシートを作成していきます。Excel帳票の取り込みは、GUIでデザインできる製品付属のSpreadJSデザイナや、オンラインデザイナを使用することで簡単に実現できます。
今回はデスクトップアプリのSpreadJSデザイナを使用していきます。無償のトライアル版は以下よりダウンロード可能です。
インストール方法等は製品ヘルプをご覧ください。

デザイナを起動し、メニューから「挿入」-「レポートシート」を選択すると、ワークブックにレポートシートが追加され、帳票のデザインが可能になります。
Excel帳票のインポート
次にメニューから「テンプレートをインポート」を選択し、表示されるウィザードからインポートしたいExcelファイルを選択して取り込みます。元のExcelファイルに設定された数式や関数はそのまま使用可能です。
レイアウトの取り込みが完了したら、明細表部分の2行目以降のデータは不要なので削除しておきます(1行目の「F17」セルの数式は使用するため、1行目はそのまま残しています。また、「A17」~「E17」に記載のデータは後述するデータバインドの手順で上書きます)。
データソース(テーブル)の追加
次に帳票に表示するデータソース(テーブル)の設定を行います。今回はREST APIのモックサーバーを手軽に構築できるライブラリ「json-server」を使って連携を行います。json-serverの使用方法については以下の記事で解説しているのでこちらをご覧ください。
今回は以下のようなJSONデータを使用します。
{
"orders":[
{
"ID": 1,
"BillNo": "WS-DF502",
"SlipNo": "GB465",
"CustomerID": 1,
"CustomerName": "長崎カントリーフーズ",
"Products": "コーヒー 250 ml",
"UnitsOnOrder": 100,
"UnitPrice": 100,
"OrderDate": "2024/01/05"
},
{
"ID": 2,
"BillNo": "WS-DF502",
"SlipNo": "GB465",
"CustomerID": 1,
"CustomerName": "長崎カントリーフーズ",
"Products": "紅茶 350 ml",
"UnitsOnOrder": 300,
"UnitPrice": 120,
"OrderDate": "2024/01/05"
},
{
"ID": 3,
"BillNo": "WS-DF502",
"SlipNo": "DK055",
"CustomerID": 1,
"CustomerName": "長崎カントリーフーズ",
"Products": "炭酸飲料 (オレンジ) 350 ml",
"UnitsOnOrder": 200,
"UnitPrice": 120,
"OrderDate": "2024/01/09"
},
{
"ID": 4,
"BillNo": "WS-DF503",
"SlipNo": "CE982",
"CustomerID": 2,
"CustomerName": "居酒屋ななべえ",
"Products": "北海道ミルク 900 ml",
"UnitsOnOrder": 300,
"UnitPrice": 250,
"OrderDate": "2024/01/12"
},
{
"ID": 5,
"BillNo": "WS-DF503",
"SlipNo": "CE982",
"CustomerID": 2,
"CustomerName": "居酒屋ななべえ",
"Products": "紅茶 350 ml",
"UnitsOnOrder": 300,
"UnitPrice": 120,
"OrderDate": "2024/01/12"
},
{
"ID": 6,
"BillNo": "WS-DF503",
"SlipNo": "CE982",
"CustomerID": 2,
"CustomerName": "居酒屋ななべえ",
"Products": "炭酸飲料 (グレープ) 500 ml",
"UnitsOnOrder": 300,
"UnitPrice": 180,
"OrderDate": "2024/01/12"
},
{
"ID": 7,
"BillNo": "WS-DF503",
"SlipNo": "CE982",
"CustomerID": 2,
"CustomerName": "居酒屋ななべえ",
"Products": "炭酸飲料 (レモン) 500 ml",
"UnitsOnOrder": 100,
"UnitPrice": 180,
"OrderDate": "2024/01/12"
},
{
"ID": 8,
"BillNo": "WS-DF503",
"SlipNo": "CE982",
"CustomerID": 2,
"CustomerName": "居酒屋ななべえ",
"Products": "炭酸飲料 (オレンジ) 500 ml",
"UnitsOnOrder": 50,
"UnitPrice": 180,
"OrderDate": "2024/01/12"
},
{
"ID": 9,
"BillNo": "WS-DF503",
"SlipNo": "CE982",
"CustomerID": 2,
"CustomerName": "居酒屋ななべえ",
"Products": "おたる白ラベル 350 ml",
"UnitsOnOrder": 100,
"UnitPrice": 210,
"OrderDate": "2024/01/12"
},
{
"ID": 10,
"BillNo": "WS-DF503",
"SlipNo": "CE982",
"CustomerID": 2,
"CustomerName": "居酒屋ななべえ",
"Products": "おたる白ラベル 500 ml",
"UnitsOnOrder": 200,
"UnitPrice": 280,
"OrderDate": "2024/01/12"
}
]
}
プロジェクトのフォルダに上記JSONファイルを配置し、ターミナル等から以下のコマンドを起動してモックのAPIを立ち上げます。
json-server orders.json -p 3000
以下のような画面が立ち上がったらAPIの起動は成功です。

APIが起動したら、「テーブルの追加」のメニューから起動したAPIのURLを設定し、「Orders」テーブルを追加します。
データバインドとセル型の設定
レポートシートに追加したデータソースから、データを流し込むセルに対してデータバインドとセル型の設定を行います。データバインドは左側の「データソース」タブからテーブルのフィールドをドラッグ&ドロップする、もしくは右側の「テンプレートセル」タブから設定します。
さらに明細表部分のセル型を「リスト」に変更します。また、今回は明細表の行数が固定のレイアウトなので、「スピル時に上書きする」のオプションにチェックを入れ、表示するデータがシート上のレイアウトを上書くように設定します。
コンテキストの設定
次にコンテキストの設定を行います。伝票番号を表示する「A17」セルとヘッダー部分とフッター部分に対して、このレポートのキー項目である請求書番号の「E6」セルを設定します。
コンテキストの詳しい解説は以下の記事もご参考ください。
画像の置き換え
Excel帳票上の画像のオブジェクトは、レポートシートにもそのまま画像のオブジェクトとして取り込むことができますが、ページングが発生するような帳票の場合、画像は1ページ目のみに表示され、2ページ目以降は表示されません。
このような場合は、画像オブジェクトの部分を、スパークライン関数のIMAGE関数を使ってbase64でエンコードした画像に置き換え、セル上に画像がスパークラインとして表示されるように設定します。これにより、セルに設定されたコンテキストが機能するようになり、2ページ目以降も画像を表示することができます。
=IMAGE("","社印")
帳票をプレビューする
以上でテンプレートシートの作成は完了です。「デザイン」メニューから「改ページプレビュー」を選択すると、デザイナ上でレポートシートをプレビュー表示できます。先ほど2ページ目に表示されなかった画像も正常に表示されています。
Webアプリケーションにレポートシートを組み込む
最後に仕上げとして作成したテンプレートシートを保存して、Webアプリケーションに組み込んでレポートシートを実行してみたいと思います。あらかじめ先ほど作成したテンプレートシートをsjs形式で保存し、プロジェクト配下にコピーしておいてください。今回はファイル名を「Invoice.sjs」とし、プロジェクト配下に作成した「reports」フォルダの配下にコピーしました。

開発環境
今回は開発環境として以下を使用します。
Webアプリケーションの作成
「index.html」ファイルを作成し、製品版、またはトライアル版に含まれるSpreadJSの各種ライブラリをコピーして参照を追加し、加えてレポートシートを表示する領域を定義します。また、今回はページングを行うためのボタンと、印刷とPDFエクスポートを行うボタンも追加します。
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<link rel="shortcut icon" href="https://demo.mescius.jp/spreadjs/demos/spread/source/favicon-ja.ico"
type="image/x-icon">
<title>レポートシートサンプル</title>
<link rel="stylesheet" type="text/css" href="css/gc.spread.sheets.excel2013white.17.1.5.css">
<script src="scripts/gc.spread.sheets.all.17.1.10.min.js" type="text/javascript"></script>
<script src="scripts/gc.spread.sheets.resources.ja.17.1.10.min.js" type="text/javascript"></script>
<script src="scripts/gc.spread.sheets.io.17.1.10.min.js" type="text/javascript"></script>
<script src="scripts/gc.spread.sheets.shapes.17.1.10.min.js" type="text/javascript"></script>
<script src="scripts/gc.spread.sheets.charts.17.1.10.min.js" type="text/javascript"></script>
<script src="scripts/gc.spread.sheets.print.17.1.10.min.js" type="text/javascript"></script>
<script src="scripts/gc.spread.sheets.pdf.17.1.10.min.js" type="text/javascript"></script>
<script src="scripts/gc.spread.report.reportsheet.17.1.10.min.js" type='text/javascript'></script>
<script src="scripts/app.js" type="text/javascript"></script>
<link rel="stylesheet" type="text/css" href="css/styles.css">
<script src="https://cdn.jsdelivr.net/npm/file-saver@2.0.5/dist/FileSaver.min.js"></script>
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/css/bootstrap.min.css" rel="stylesheet">
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0/dist/js/bootstrap.bundle.min.js"></script>
</head>
<body>
<div class="btn-container">
<button id="print" class="btn btn-primary">印刷</button>
<button id="pdf" class="btn btn-primary">PDF出力</button>
<button id="previous" class="btn btn-secondary">前のページ</button>
<span id="current"></span>ページ/<span id="all"></span>ページ
<button id="next" class="btn btn-secondary">次のページ</button>
</div>
<div class="show-area">
<div id="ss"></div>
</div>
</body>
</html>
「scripts」フォルダ配下に「app.js」ファイルを作成し、先ほど保存したsjsファイルを読み込んでレポートシートを実行します。
※ ライセンスキーを設定しない場合、トライアル版を示すメッセージが表示されます。ライセンスキーの設定方法についてはこちらをご覧ください。
レポートシートの表示のほか、ページングやPDF出力の機能も実装しています。PDF出力にはフォントの埋め込みが必要なため、レポート中で使用しているIPAexゴシックフォントを環境にコピーして埋め込みます。各機能の詳しい実装方法の解説は以下の入門記事をご参考ください。
// 日本語カルチャー設定
GC.Spread.Common.CultureManager.culture("ja-jp");
GC.Spread.Sheets.LicenseKey = "ここにSpreadJSのライセンスキーを設定します";
// SpreadJSの設定
document.addEventListener("DOMContentLoaded", () => {
const spread = new GC.Spread.Sheets.Workbook("ss");
const printButton = document.getElementById('print');
const pdfButton = document.getElementById('pdf');
const previousButton = document.getElementById('previous');
const nextButton = document.getElementById('next');
let reportSheet;
//------------------------------------------
// PDFエクスポートに必要なフォントを登録します
//------------------------------------------
registerFont("IPAexゴシック", "normal", "fonts/ipaexg.ttf");
//----------------------------------------------------------------
// sjs形式のテンプレートシートを読み込んでレポートシートを実行します
//----------------------------------------------------------------
console.log("読み込み開始");
const res = fetch('reports/Invoice.sjs').then((response) => response.blob())
.then((myBlob) => {
console.log(myBlob);
spread.open(myBlob, () => {
console.log(`読み込み成功`);
reportSheet = spread.getSheetTab(0);
// レポートシートのオプション設定
reportSheet.options.renderMode = 'PaginatedPreview';
reportSheet.options.printAllPages = true;
// レポートシートの印刷設定
var printInfo = reportSheet.printInfo();
printInfo.showBorder(false);
printInfo.zoomFactor(1);
reportSheet.printInfo(printInfo);
reportSheet.refresh();
initPage()
}, (e) => {
console.log(`***ERR*** エラーコード(${e.errorCode}) : ${e.errorMessage}`);
});
});
//------------------------------------------
// 印刷ボタン押下時の処理
//------------------------------------------
printButton.onclick = function () {
spread.print();
}
//------------------------------------------
// PDF出力ボタン押下時の処理
//------------------------------------------
pdfButton.onclick = function () {
spread.savePDF(function (blob) {
//saveAs(blob, 'download.pdf');
var url = URL.createObjectURL(blob);
window.open(url);
}, function (error) {
console.log(error);
}, {
title: '請求書',
author: 'テストAuthor',
subject: 'テストSubject',
keywords: 'テストKeywords',
creator: 'テストCreator'
})
}
//------------------------------------------
// 前のページボタン押下時の処理
//------------------------------------------
previousButton.onclick = function () {
const page = reportSheet.currentPage();
if (page != 0) {
reportSheet.currentPage(page - 1);
initPage()
}
}
//------------------------------------------
// 次のページボタン押下時の処理
//------------------------------------------
nextButton.onclick = function () {
const page = reportSheet.currentPage();
if (page < reportSheet.getPagesCount() - 1) {
reportSheet.currentPage(page + 1);
initPage()
}
}
//------------------------------------------
// 現在のページと全ページ数の表示
//------------------------------------------
function initPage() {
document.getElementById('current').innerHTML = reportSheet.currentPage() + 1;
document.getElementById('all').innerHTML = reportSheet.getPagesCount();
}
//------------------------------------------
// フォントファイルの読み込み
//------------------------------------------
function registerFont(name, type, fontPath) {
var xhr = new XMLHttpRequest();
xhr.open('GET', fontPath, true);
xhr.responseType = 'arraybuffer';
xhr.onload = function (e) {
if (this.status == 200) {
var fontArrayBuffer = this.response;
var fonts = {};
fonts[type] = fontArrayBuffer;
GC.Spread.Sheets.PDF.PDFFontsManager.registerFont(name, fonts);
}
};
xhr.send();
}
});
「css/styles.css」を作成し、スタイルの設定を追加します。
body{
width: 610px;
}
.btn-container{
margin: 15px;
}
.show-area{
margin: 15px;
border: solid black;
}
#ss{
width:580px;
height:900px
}
以上でWebアプリケーションの作成は完了です。「index.html」を右クリックして「Open with Live Server」を実行し、開発サーバーでアプリケーションを起動します。
※ アプリケーションの実行前に、あらかじめjson-serverを実行してAPIを起動してください。

起動したアプリケーション上でレポートシートが実行され、Excel帳票から移行したWeb帳票をブラウザ上に表示することができました。
もちろん印刷やPDF出力も可能です。
今回作成したアプリケーションはこちらからダウンロード可能です。
さいごに
今回はSpreadJSのレポートシート機能を使用して、既存のExcel帳票をモダンなWeb帳票に移行する方法をご紹介しました。Excelと高い互換性を持つSpreadJSであれば、既存のExcel帳票資産を驚くほどスピーディにモダンなWeb帳票に移行できますので、Excel帳票のモダナイズをご検討されている方は是非お試しください。
弊社Webサイトには、レポートシートで作成した数々の帳票サンプルが確認できるデモアプリケーションや、無料のトライアル版がございますので、こちらもご確認ください。