2012/02/20

JavaScript (WSH) でExcelファイル読み込み

Excelのテーブル定義書を元に、Java Beansの元となるテキストを作成するJavaScriptを書きました。
14行目からのCELL objectの定義を少し修正すれば、汎用的に使えると思います。

行が結合されてたりすると、途端に破綻してしまいますが...。

/*
 * Excelファイル読み込み
 * テーブル定義書から必要な情報を取得し、classの元データを生成する
 */

/** Excelファイル */
var XLS_FILES = [
 "3.1. テーブル定義\\テーブル定義書_1.xls",
    :
 "3.1. テーブル定義\\テーブル定義書_N.xls"
];

/** Cell位置定義 */
var CELL = {};
/** テーブル名 (物理名) */
CELL.TABLE_NAME_ROW = 8;
CELL.TABLE_NAME_COL = 1;
/** テーブル名 (正式名) */
CELL.TABLE_DESC_ROW = 8;
CELL.TABLE_DESC_COL = 12;

/** フィールド情報 開始位置定義 */
CELL.START_ROW = 10;
CELL.FIELD_NAME_COL = 4;  //フィールド名
CELL.FIELD_TYPE_COL = 12; //種類
CELL.FIELD_DESC_COL = 18; //概要

/** テーブル定義 シート名 */
var SHEET_NAME = 'フィールド';

var fso = new ActiveXObject('Scripting.FileSystemObject');


/**
 * Excelファイルを開く
 */
function readExcel(xlsFile){
 //ファイル存在チェック
 if( ! fso.FileExists(xlsFile) ){
  return;
 }
 
 var xls = null;
 var book = null;
 var fields = [];
 
 try{
  //Excel起動
  xls = new ActiveXObject('Excel.Application');
  //Excelファイル open
  book = xls.Workbooks.Open(xlsFile);
  //シート指定
  var sheet = book.WorkSheets(SHEET_NAME);

  // sheet.Cells(row, col);
  var tableName = sheet.Cells(CELL.TABLE_NAME_ROW, CELL.TABLE_NAME_COL).Value;
  var tableDesc = sheet.Cells(CELL.TABLE_DESC_ROW, CELL.TABLE_DESC_COL).Value;
  /*
   table = {
   name:
   description: 
   }
   */
  fields = [{ 'name':tableName, 'description':tableDesc }]; //1要素目はtable名
  /*
  field = {
   name:
   type:
   length:
   description:
  }
  */

  var reg = /\([0-9]+\)/;
  var row = CELL.START_ROW;
  while(1){
   var c = sheet.Cells(row, CELL.FIELD_NAME_COL).Value;
   if( c == null || c.length == 0){
    //フィールド名定義がない→ループ終了
    break;
   }
   //フィールド名
   var name = c;
   //種別
   var type = sheet.Cells(row, CELL.FIELD_TYPE_COL).Value;
   //長さ
   var length = 0;
   if( reg.test(type) ){
    var m = type.match(reg).join('');
    m = m.replace(/\(|\)/, '');
    length = parseInt(m);
   }
   //概要
   var desc = sheet.Cells(row, CELL.FIELD_DESC_COL).Value;
   if( desc == null || desc.length == 0 ){
    desc = '';
   }
   fields[fields.length] = {
     'name':name,
     'type':type,
     'length':length,
     'description': desc
    };

   row++;
  }
  
 }catch(e){
  //例外発生 -> 無視
 }finally{
  try{
   //Excelファイル close
   book.Close();
  }catch(e){}
  try{
   //Excel終了
   xls.Quit(); //きちんとQuitしないとプロセスが残る
   xls = null;
  }catch(e){}
 }
 return fields;
}

/**
 * アンダーバーを除去し、lowerCamelCaseに変換する
 */
function toLowerCamelCase(str){
 var tmp = str.toLowerCase();
 var arr = tmp.split('_');
 var ret = arr[0];
 for(var i=1; i<arr.length; i++){
  ret += arr[i].charAt(0).toUpperCase() + arr[i].slice(1);
 }
 return ret;
}

/**
 * アンダーバーを除去し、UpperCamelCaseに変換する
 */
function toUpperCamelCase(str){
 var tmp = str.toLowerCase();
 var arr = tmp.split('_');
 var ret = '';
 for(var i=0; i<arr.length; i++){
  ret += arr[i].charAt(0).toUpperCase() + arr[i].slice(1);
 }
 return ret;
}

/** JavaDocコメント文字列 出力 */
function javadocString(msg){
 return ['/**',msg,'*/'].join(' ');
}

/** DBMSタイプ→Java型に変換 */
function getType(t){
 var ret = 'String';
 
 if( /VARCHAR/i.test(t) ){
  ret = 'String';
 }else if( /NUMBER/i.test(t) ){
  ret = 'int';
 }else if( /DATE/i.test(t) ){
  ret = 'String';
 }
 
 return ret;
}


(function(){
 for( var i=0; i<XLS_FILES.length; i++ ){
  //Excelファイル読み込み
  var fields = readExcel(XLS_FILES[i]);
  //1つめの要素はテーブル定義
  var tableName = fields[0].name;
  var tableDesc = fields[0].description;
  //結果出力ファイル
  var fileName = tableName + '_' + tableDesc + '.txt';
  WScript.Echo(fileName);
  
  //出力ファイルデータ
  var dat = [];
  
  dat[dat.length] = javadocString(tableDesc);
  dat[dat.length] = 'final public static String TABLE_NAME = "' + tableName + '";';
  dat[dat.length] = '';
  
  //フィールド順の定義
  for( var j=1; j<fields.length; j++ ){
   dat[dat.length] = javadocString(fields[j].description);
   dat[dat.length] = 'final public static int FIELD_' + fields[j].name.toUpperCase() + ' = ' + j + ';';
  }
  dat[dat.length] = '';
  
  //フィールド変数
  for( var j=1; j<fields.length; j++ ){
   dat[dat.length] = javadocString(fields[j].description);
   var type = getType(fields[j].type);
   dat[dat.length] = ['private', type, fields[j].name.toLowerCase()].join(' ') + ';';
  }
  
  //ファイル出力
  var f = fso.CreateTextFile(fileName, true);
  f.WriteLine(dat.join(String.fromCharCode(13) + String.fromCharCode(10)));
  f.Close();
 }
})();

0 件のコメント:

コメントを投稿