string形式のファイル名の作成

csv形式のファイルからデータをインポートして、処理した上でcsvファイルと同じファイル名のxlsxファイルの作成を考えております。
file = "C:\asdf.csv";
[filepath,name,ext] = fileparts(file)
としてcsvのファイル名をstring形式で取り込み
処理したデータTを
writetable(T,name.xlsx)
とすればできるのではないか考えたのですができませんでした。
良い方法があれば教えていただけないでしょうか?

댓글 수: 4

Atsushi Ueno
Atsushi Ueno 2022년 7월 3일
xlsxファイルの作成にwritetable関数を使用するのであれば、csv形式のファイルからデータをインポートするのにもreadtable関数を使用すれば良いのではないでしょうか?
Atsushi Ueno
Atsushi Ueno 2022년 7월 3일
writetable(T,name.xlsx)
ではなく
writetable(T,'name.xlsx')
とする必要がありますが、そこは問題ないでしょうか?
Koji
Koji 2022년 7월 3일
ありがとうございます。
writetable(T,'name.xlsx')
これも試しましたが、name.xlxsができてしまい、
求めているasdf,xlsxはできませんでした。
最終的なファイルはcsv形式でもいいのですが、データ処理後のファイル名に元々のファイル名asdfを反映できればと考えております。
Atsushi Ueno
Atsushi Ueno 2022년 7월 3일
そういう事でしたか。それならこれでファイル名の拡張子だけ変更して保存する事が出来ます
file = "C:\asdf.csv";
[filepath,name,ext] = fileparts(file)
writetable(T,[filepath,name,'.xlsx']);

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

 채택된 답변

Hernia Baby
Hernia Baby 2022년 7월 4일

1 개 추천

エラー: writetable (line 152)
FILENAME は空でない文字ベクトルまたは string スカラーでなければなりません。
---------------------------------------------------
これはcatが配列の結合だからです。
string配列でなく、スカラーにするにはappendを使用してください。
file = "C:\asdf.csv";
[filepath,name,ext] = fileparts(file)
filepath = ""
name = "C:\asdf"
ext = ".csv"
以下がcatでの連結です
[filepath,name,'.xlsx']
ans = 1×3 string array
"" "C:\asdf" ".xlsx"
以下がappendでの連結です
filepath + name + '.xlsx'
ans = "C:\asdf.xlsx"
※関係ないですがMATLAB Answers上ではfilepartsがCドライブがないためか、filepathが空になるんですね。

댓글 수: 2

system('cat /proc/version');
Linux version 5.4.185-0504185-generic (kernel@gloin) (gcc version 9.4.0 (Ubuntu 9.4.0-1ubuntu1~20.04)) #202203160950 SMP Wed Mar 16 14:00:16 UTC 2022
厳密に言うとCドライブが無い事が原因ではなく、Linuxプラットフォームではfileparts関数がファイルパスの区切り文字としてスラッシュ(/)しか受け付けない事が原因ですね。Windowsプラットフォームではスラッシュ(/)もバックスラッシュ(\)も使えるので、fileparts関数は両方とも使えると勘違いしていました。
% On Microsoft Windows systems, you can use either forward (/) or back (\) slashes
% as path delimiters, even within the same path. On Unix and Macintosh systems, use
% only / as a delimiter.
Hernia Baby
Hernia Baby 2022년 7월 4일
なるほどLinux環境が原因だったんですね…!勉強になるなあ…

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

추가 답변 (2개)

Koji
Koji 2022년 7월 3일

0 개 추천

ありがとうございます。
file = "C:\asdf.csv";
[filepath,name,ext] = fileparts(file)
writetable(T,[filepath,name,'.xlsx']);
上記で試したところ
file、filepath、nameはstring形式でワークスペースには現れていますが
エラー: writetable (line 152)
FILENAME は空でない文字ベクトルまたは string スカラーでなければなりません。
となってしまいました。
Koji
Koji 2022년 7월 4일

0 개 추천

お二方ご助言ありがとうございました。
str1=append(name,'.xlsx');
writetable(T,str1);
お陰様で上記で、求めたいた元々のファイル名を使ったxlsxファイルを作成することができました。

댓글 수: 1

Atsushi Ueno
Atsushi Ueno 2022년 7월 4일
おっとこれはすいません。間違えてstring型に文字ベクトルをくっつけてしまいました。

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

카테고리

도움말 센터File Exchange에서 Text Data Preparation에 대해 자세히 알아보기

제품

릴리스

R2019b

질문:

2022년 7월 3일

댓글:

2022년 7월 4일

Community Treasure Hunt

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

Start Hunting!