2016-05-02 13 views
0

ドライブのアカウントに複数のシートがあるExcelワークブック(スプレッドシート)を持っています。AppsスクリプトスプレッドシートでJSONを取得するのが非常に遅い

私はこのスクリプト(Apps Script)を使ってアンドロイドデバイスからJSON形式のレコードを取得しています。このレコードはほとんどなくても大量のレコードが残っていない場合に動作します。

function traerRubros() { 
    var libro = SpreadsheetApp.openByUrl('https://docs.google.com/spreadsheets/d/1-Vv3tsn7QYDa7rOsha4ebj9vJyjegG7j-xpDMbOOAuY/edit#gid=825509855'); 

    var sheet = libro.getSheetByName('Articulos'); 

    var json1 = convertSheet2JsonText(sheet); 

    return JSON.stringify(json1); 
} 

function convertSheet2JsonText(sheet) { 
    // first line(title) 
    var colStartIndex = 1; 
    var rowNum = 1; 
    var firstRange = sheet.getRange(1, 1, 1, sheet.getLastColumn()); 
    var firstRowValues = firstRange.getValues(); 
    var titleColumns = firstRowValues[0]; 

    // after the second line(data) 
    var lastRow = sheet.getLastRow(); 
    var rowValues = []; 
    for(var rowIndex=2; rowIndex<=lastRow; rowIndex++) { 
    var colStartIndex = 1; 
    var rowNum = 1; 
    var range = sheet.getRange(rowIndex, colStartIndex, rowNum, sheet.getLastColumn()); 
    var values = range.getValues(); 
    rowValues.push(values[0]); 
    } 

    // create json 
    var jsonArray = []; 
    for(var i=0; i<rowValues.length; i++) { 
    var line = rowValues[i]; 
    var json = new Object(); 
    for(var j=0; j<titleColumns.length; j++) { 
     json[titleColumns[j]] = line[j]; 
    } 
    jsonArray.push(json); 
    } 
    return jsonArray; 
} 

なぜそれほど時間がかかりますか? このスクリプトには、より高速化するための最適化がありますか? レコードをすばやく取得するにはどのような方法をお勧めしますか?

答えて

2

ループ内でgetRange()またはgetValues()を実行すると、コードが遅くなります。次に、getValues()はArray [] []を返します。別の配列にコピーする必要はありません。

// after the second line(data) 
    var lastRow = sheet.getLastRow(); 
    var colStartIndex = 1; 
    var rowStart = 2; // Column and Rows start at index 1 
    var rowValues = sheet.getRange(rowStart, colStartIndex, sheet.getLastRow(), sheet.getLastColumn()).getValues(); 

// create json 
    var jsonArray = []; 
... 
... 
+0

ありがとうございます、私は現在コードを使用してcsvに渡しています。 – seba123neo

関連する問題