How can I load .psv file to MATLAB?

7 次查看(过去 30 天)
I have downlaoded datase from PhysioNet/Computing in Cardiology Challenge 2019. Here all the data are in .psv format. Can anyone help me showing the way of loading this format data.
  5 个评论
Diana Simona
Diana Simona 2019-10-11
编辑:Diana Simona 2019-10-11
Hey,
Have you figured it out how to do this?
Because i have encountered the same problem, i can't see and extract the values.
I can open the file and see the headers (HR|O2Sat|Temp|SBP|MAP|DBP|Resp etc). I can also see some values here and there, but i get a lot of NaN values.
ps: i dont have a lot of Matlab experience
Walter Roberson
Walter Roberson 2019-10-11
What happened when you used the two methods that Jan suggested?

请先登录,再进行评论。

采纳的回答

Jan
Jan 2019-5-9
编辑:Jan 2019-5-13
A small example would reveal, if this guess is correct: It is a pipe-separated text file. Then:
readmatrix(filename, 'Delimiter', '|', 'FileType', 'text')
[EDITED] And a dull manual method:
function [Data, Header] = ReadPSV(File)
% [Data, Header] = ReadPSV(File)
% INPUT:
% File: Char vector or string: Name of the file
% OUTPUT:
% Data: Double matrix, [nVariables x nFrames]
% Header: {nVariables x 1} cell string
%
% License: CC BY-SA 3.0
[fid, msg] = fopen(File, 'rt');
assert(fid ~= -1, 'Tools:ReadPSV:MissFile', ...
'Cannot open file:%s\n%s', File, msg);
Line1 = fgetl(fid); % Import 1st line
Header = strsplit(Line1, '|'); % Reply variables as cell string
n = numel(Header); % Number of variables
% [EDITED] start
str = fread(fid, [1, inf], '*char'); % Import data as string
str(str == char(10)) = '|'; % Replace line break by |
% [EDITED] end
Data = sscanf(str, '%f|', [n, inf]); % Extract numbers
fclose(fid);
end
  3 个评论
Jan
Jan 2019-5-13
@Walter: Thank you. Fixed. And the next bug was:
str(str = char(10)) = '|';
% ^ Of course: ==

请先登录,再进行评论。

更多回答(1 个)

Ricardo Salinas Martinez
Hello!
Jan's answer works preaty well, but if you read the codes provided by the challenge you will see how they read the files and there is no need for you to read them differently.

类别

Help CenterFile Exchange 中查找有关 Data Import and Export 的更多信息

标签

Community Treasure Hunt

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

Start Hunting!

Translated by