LoginSignup
9
11

More than 3 years have passed since last update.

【MATLAB】CSVファイルに計算セル(数式セル)を追加してEXCELファイルとして保存する

Last updated at Posted at 2021-01-23

はじめに

matlabは数値計算に強く,音響ファイルを開いて振幅グラフを出力したりFFTしたりといったことが簡単に行える.
様々な分析結果を客先に提出する場合は,弊社の場合はexcelファイル(xlsx)の場合が多く,また,客がパラメタを変えながら確認出来るように,計算結果は生の数値ではなく,計算セルを使用している.

「計算セル」というのはここでは
=round(A1*B1, 0)
みたいな感じの数式の入ったセルのことを言っている.

計算セルがあるために,今までは

  1. matlabで数値計算してCSVファイルに保存する
  2. excelCSVファイルを開き,計算セルを追加してxlsxで保存する

という手順を踏んでおり,計算セルを追加する作業がめんどっちーだった.

今回は上記作業を自動化するということで,matlabで身長及び体重が入力されたCSVファイルを開き,BMIを計算してxlsxで保存するスクリプトを書いてみる.

使用するCSVファイル

以下のようなCSVファイルを用意した.

1

名前 生年月日 身長(cm) 体重(kg)
hoge huga yyyy/m/d x y

これを適当な名前(身長体重.csv)で保存した.

BMI値をmatlabで計算

実装

clc
close all
clear all

path = 'C:\Users\hogehoge';
file = '身長体重.csv';
% 名前,生年月日,身長(cm),体重(kg)
% 桜 衣之,2021/4/4,155,47
% ...
filepath = fullfile(path, file);

% ファイルを開いてcellに格納
T = readcell(filepath,'DatetimeType','text');

% 身長(cm)
height = cell2mat(T(2:end,3));
height = height / 100;% 身長(m)に直す
% 体重(kg)
weight = cell2mat(T(2:end,4));
% BMI = 体重kg ÷ (身長m)^2
BMI = weight ./ (height .^2);
% cell配列にする
TBMI = num2cell(BMI);
TBMI = [{'BMI'}; TBMI];% 1行目を追加

% cellの連結
Tout = [T TBMI];

% ファイルに書き込む
[path, file] = fileparts(filepath);
newFile = sprintf('%s_addBMI.xlsx', file);
outputFilePath = fullfile(path, newFile);
writecell(Tout, outputFilePath);

追加したい列をcellとして用意して,readcellで読み取ったcellに連結するだけである.

結果

結果は以下のようになり,BMIの計算結果を追加することが出来た.

BMI値をexcelで計算

前節でBMIの計算結果が追加され,xlsxファイルとして保存することが出来た.
しかし,やりたいのは計算セルの追加である.
以下の図のように,BMIをmatlabではなくexcelで計算させたいのである.

実装

%(Toutを求めるところまでは上と同じなので中略)

% 計算セルをさらに追加する
BMI2 = cell(size(TBMI));
BMI2(1) = {"計算セル"};
for n = 2:length(BMI2)
    % =D2/(C2/100)^2
    BMI2(n) = {"=D" + n + "/(C" + n + "/100)^2"};
end
Tout2 = [Tout BMI2];

% ファイルに書き込む
[path, file] = fileparts(filepath);
newFile = sprintf('%s_addBMI.xlsx', file);
outputFilePath = fullfile(path, newFile);
writecell(Tout2, outputFilePath,'UseExcel',true);% UseExcelオプションを追加

計算セルの追加方法については,【MATLAB】ハイパーリンク付きテキストのExcel への書き込み自動化を参考にした.
やってることは簡単で,数式をそのままstringに入れて,出力する際にwritecellUseExcelオプションをつけるだけであった.UseExcelオプションは気付かなかったわね.

また,DCなどの列名がハードコーディングになっているが,これが気になる場合は以下などに列番号をエクセル表記(またはその逆)に変換する実装がある.
I need to convert a number into its column name equivalent

結果

期待通りの結果となった.
もちろん,excel上で体重などの値を編集するとBMIの値も自動更新される.

まとめ

今回はmatlabから計算セルの入ったexcelファイルを作成した.
この調子でexcelと和解していきたい.

9
11
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
9
11