見出し画像

OfficeScripts | 配列

こんにちは。ふらです。今日はOfficeScriptsを使った、配列の利用について紹介したいと思います。


OfficeScritpsの配列でよく使う配列のコード集

function main(workbook: ExcelScript.Workbook) {

    //1次元配列の初期値を設定
    let array_data1: number[] = [1, 2, 3];

    //1次元配列の要素を取得
    console.log(array_data1[0]);

    //1次元配列へ要素を追加する(末尾に追加)
    array_data1.push(4);
    array_data1.push(5);

    //1次元配列へ要素を追加する(先頭に追加)
    array_data1.unshift(0);

    //1次元配列の要素を削除する(末尾)
    array_data1.pop()

    //1次元配列の要素を削除する(先頭)
    array_data1.shift()

    console.log(array_data1); // [1, 2, 3, 4]

    // -----------

    //2次元配列の初期値を設定
    const array_data2: string[][] = [
        ["01", "02", "03", "04", "05",],
        ["06", "07", "08", "09", "10",],
        ["11", "12", "13", "14", "15",],
        ["16", "17", "18", "19", "20",],
        ["21", "22", "23", "24", "25",]
    ];
    console.log(array_data2);

    //2次元配列の要素を取得
    console.log(array_data2[0][0]);

    //シートのデータを2次元配列として取得する
    const sh = workbook.getWorksheet("Sheet1");
    const values = sh.getUsedRange().getValues();
    console.log(values);

    //2次元配列のデータ加工例
    for (let i = 0; i < values.length; i++) {

        //1列目の文字列先頭にすべて●を入れる
        if (values[i][0]) {
            values[i][0] = "●" + values[i][0];
        }

    }

    //加工した2次元配列をシートに貼り付け
    sh.getRangeByIndexes(0, 0, values.length, values[0].length).setValues(values);
    sh.getRange("A1").select();

}

OfficeScritpsでは2次元配列が必須

VBA を使う方だと、各セルのデータを読み取って条件判定して、処理して...ということをよくされているのではないのでしょうか。
(私はよくしていました。)

for文で各セルを回すので、コードは読みやすいし、使いやすいです。

OfficeScripts ではこの手が使えません。for文内で「getValue」をすると、とても処理速度が遅くなります。こんな警告メッセージもでます。

Invoking read methods inside of a loop could lead to slow performance of the script. For more information, please visit https://aka.ms/office-scripts-performance(Office Scripts Error)

さてさてそれではセルのデータを読み取ってデータ処理ができない!というのを解決してくれるのが2次元配列です。

一度全てのセル情報を読み取って2次元配列に格納して、2次元配列を一度でシートに書き込む。こうすることで、
格段に処理が速くなります。

ただ2次元配列は理解が難しいし、後で見返して混乱することも多々あるので、プログラミング初心者の方にはハードルが高いかも
しれませんが、OfficeScriptsをやっていきたい!となると通らなければ行けない道だと思いますので...

一緒に頑張りましょう。

どのくらい処理速度に差があるのか?

良い例と悪い例で比較をしてみましょう。下記は200行のデータをかける2したときにデータ処理速度を比較したものです。

//2次元配列で、データ取得して書き込み。良い例
function main(workbook: ExcelScript.Workbook) {

    //シート取得
    let sh = workbook.getActiveWorksheet();
    //セル有効範囲の取得
    const rangeValues = sh.getUsedRange().getValues();

    //データを回す
    const start = performance.now();
    for (let j = 3; j < rangeValues.length; j++) {
        //対象データを変数格納
        let range = rangeValues[j][0];
        //データ処理と書き込み
        workbook.getActiveWorksheet().getCell(j, 1).setValue(Number(range)*2);
    }
    const end = performance.now();
    workbook.getActiveWorksheet().getCell(1, 2).setValue(end - start);

}
//1つずつgetValueして、データ取得して書き込み。悪い例
function main(workbook: ExcelScript.Workbook) {

    //シート取得
    let sh = workbook.getActiveWorksheet();

    //データを回す
    const start = performance.now();
    for (let j = 3; j < 200; j++) {
        //対象データを変数格納
        let range = sh.getCell(j, 0).getValue();
        //データ処理と書き込み
        workbook.getActiveWorksheet().getCell(j, 1).setValue(Number(range) * 2);
    }
    const end = performance.now();
    workbook.getActiveWorksheet().getCell(1, 2).setValue(end - start);

}

2次元配列を使った良い例では、0.0225秒で処理が完了しましたが、getValue()を使った悪い例では40秒も時間がかかりました。違いは歴然ですね。OfficeScritpsはまだまだコードの情報も少なく勉強しにくい
言語であることは否めませんが、ご興味のある方は、ぜひ私の投稿も参考資料の一部にして頂けますと幸いです。


#OfficeScripts #Officeスクリプト #プログラミング #自動化 #業務効率化 #エクセル #M365 #ExcelOnline #osts

いいなと思ったら応援しよう!