Tableデータ名に​日本語が含まれている​場合の処理

조회 수: 112(최근 30일)
Yuya Iwasaki
Yuya Iwasaki 2020년 10월 1일
편집: stozaki 2020년 10월 2일
いつも大変お世話になっております。
エクセルで編集されたデータ名に日本語が含まれており、それをそのままテーブルに取り込むと、日本語の部分が文字化けしてしまいます。
下記リンクを参照にコーディングしましたが、文字化けしてしまいます。
解決策などはありますでしょうか。
よろしくお願いいたします。
  댓글 수: 2
Yuya Iwasaki
Yuya Iwasaki 2020년 10월 2일
対象データ添付します。
少しデータ名編集しています。
また今回はcsvのデータでした。
コードは下記です。
TD2 = readtable(filePath,'encoding','UTF-8');
filePathはそのファイルの絶対パスを記入しています。

댓글을 달려면 로그인하십시오.

채택된 답변

stozaki
stozaki 2020년 10월 2일
편집: stozaki 2020년 10월 2일
Yuya Iwasaki様
データの添付及び、コマンド例を記載頂きましてありがとうございます。
ご利用頂いているMATLABバージョンがR2017aとのことで、行名に日本語等のマルチバイト文字取得の対応が出来ないようです。R2019b以降ですと、以下のオプション引数をつけることで読み込みができます。
詳細はR2019bのリリースノートを参照頂けますでしょうか?
TD2 = readtable('sample.csv','PreserveVariableNames',true)
R2017bの場合、出力が 'String' 型ではありますが、以下のコマンドで取得が可能かと思います。
% 変数初期化
filename = 'sample.csv';
delimiter = ',';
formatSpec = '%s%s%s%s%s%[^\n\r]';
% テキスト ファイルを開きます。
fileID = fopen(filename,'r');
% データの列を書式設定に従って読み取ります。
dataArray = textscan(fileID, formatSpec, 'Delimiter', delimiter, 'TextType', 'string', 'ReturnOnError', false);
% テキスト ファイルを閉じます。
fclose(fileID);
% TD2 に出力
TD2 = [dataArray{1:end-1}];
% 一時変数のクリア
clearvars filename delimiter formatSpec fileID dataArray ans;
ご検討頂けますでしょうか。
stozaki

추가 답변(0개)

제품


릴리스

R2017a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!