read csv data with numbers, characters and text

41 ビュー (過去 30 日間)
Simon Lind
Simon Lind 2023 年 5 月 22 日
コメント済み: Cris LaPierre 2023 年 5 月 23 日
Greetings
Does anyone have any idea on how to import numerical data from a csv file of the following format:
STATION DATE LATITUDE LONGITUDE ELEVATION NAME PRCP PRCP_ATTRIBUTES TMAX TMAX_ATTRIBUTES TMIN TMIN_ATTRIBUTES
BC000068026 01/02/32 -18.367 21.85 1000 SHAKAWE, BC 0 ,,Q
I'm attaching a sample file
Matlab2016b
Thank you very much in advance
  6 件のコメント
Simon Lind
Simon Lind 2023 年 5 月 22 日
detectImportOptions is a very good tip
Image Analyst
Image Analyst 2023 年 5 月 22 日
If the format is too custom and varies from file to file, you may have to write your own custom reader where you read a line at a time and parse it appropriately.

サインインしてコメントする。

採用された回答

Cris LaPierre
Cris LaPierre 2023 年 5 月 23 日
編集済み: Cris LaPierre 2023 年 5 月 23 日
Have you tried readtable? What didn't work about it? I get the results I would expect. It even successfully ignored the delimiters inside quotes.
The file has 12 delimited fields, the names of which are given in the first line of your file.
The "SHAKAWE, BC" AND ",,Q" are each considered single variables (NAME and PRCP ATTRIBUTES). When I use readtable in R2016b with no options, I get this:
Notice the warning about dates. I suspect it should be dd/MM/yy. Use the options to fix that.
opts = detectImportOptions('sample.csv');
opts = setvaropts(opts,'DATE','InputFormat','dd/MM/yy');
data = readtable('sample.csv',opts)
  3 件のコメント
Simon Lind
Simon Lind 2023 年 5 月 23 日
移動済み: Cris LaPierre 2023 年 5 月 23 日
I followed your advices. This was what I finally did and it works
Thank you very much
opts.SelectedVariableNames = {'DATE','LATITUDE','LONGITUDE','PRCP'};
T = readtable([datapath myfile],opts);
t = table2array(T(:,1));
lat = table2array(T(:,2));
lon = table2array(T(:,3));
p = table2array(T(:,4));
lon = str2num(cell2mat(lon));
lat = str2num(cell2mat(lat));
t = datenum(t);
p = str2num(cell2mat(p));
Cris LaPierre
Cris LaPierre 2023 年 5 月 23 日
Why all the postprocessing? See how to access data in tables.

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeData Import and Analysis についてさらに検索

タグ

製品


リリース

R2016b

Community Treasure Hunt

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

Start Hunting!

Translated by