Open selected csv file and plot

Hi everyone, I have excel file with many spreadsheets; I convert them into csv file. My problem I have now is I want to open the csv file using uigetfile, and plot that file. However, I don't know how to plot it since different file has different data size. Can anyone help me with that? Thanks alot.

1 Commento

noname
noname il 24 Mar 2018
I'd like to use the multiselect to open more than one file, then plot them, but I don't know how to approach it. I'd really appreciate if anyone could help me. Thanks alot!

Accedi per commentare.

 Risposta accettata

Try this:
% Have user browse for a file, from a specified "starting folder."
% For convenience in browsing, set a starting folder from which to browse.
startingFolder = pwd; % or 'C:\wherever';
if ~exist(startingFolder, 'dir')
% If that folder doesn't exist, just start in the current folder.
startingFolder = pwd;
end
% Get the name of the file that the user wants to use.
defaultFileName = fullfile(startingFolder, '*.*');
[baseFileName, folder] = uigetfile(defaultFileName, 'Select a file');
if baseFileName == 0
% User clicked the Cancel button.
return;
end
fullFileName = fullfile(folder, baseFileName)
data = csvread(fullFileName);
x = data(:, 1); % Or wherever
y = data(:, 2);
plot(x, y, 'b*-', 'LineWidth', 2);
grid on;
title('Y vs. X', 'FontSize', 20);
xlabel('X', 'FontSize', 20);
ylabel('Y', 'FontSize', 20);

7 Commenti

noname
noname il 14 Mar 2018
I can't get it plot. I only can open the file. It said:
Undefined function or variable 'fullFileName'.
Error in test (line 12) data = csvread(fullFileName);
Image Analyst
Image Analyst il 15 Mar 2018
Modificato: Image Analyst il 15 Mar 2018
I just tried it and it works fine. Do you NOT have this line of code in there:
fullFileName = fullfile(folder, baseFileName)
??? That defines the variable, but you're saying it tells you the variable is not assigned, meaning that you did not put the line of code in there. Attach your ACTUAL code if you need more help.
noname
noname il 15 Mar 2018
Thanks, I will try it. Do you know how to plot it using boxplot? Again, thank you for your time.
I don't use boxplot(). What I'd do is to look in the documentation for an example of how to use it.
noname
noname il 15 Mar 2018
Modificato: per isakson il 16 Mar 2018
So I basically copy and paste your code on my file. however, I got this error, do you think I need to change my csv format?
Error using dlmread (line 138)
Mismatch between file and format string.
Trouble reading number from file (row 1u, field 1u) ==>
numberone,numbertwo,numberthree\n
Error in csvread (line 47)
m=dlmread(filename, ',', r, c);
Error in test (line 16)
data = csvread(fullFileName);
per isakson
per isakson il 16 Mar 2018
Modificato: per isakson il 16 Mar 2018
>> m=dlmread( 'Book3.csv', ',', 1,0);
works fine, but
>> m=dlmread( 'Book3.csv', ',', 0,0);
Error using dlmread (line 147)
Mismatch between file and format string.
Trouble reading 'Numeric' field from file (row number 1, field number 1) ==>
numberone,numbertwo,numberthree,numberfour\n
You must chose values of r and c that doesn't include the header.
noname
noname il 24 Mar 2018
Thank you all for your help. I found my solution. :)

Accedi per commentare.

Più risposte (0)

Categorie

Scopri di più su Environment and Settings in Centro assistenza e File Exchange

Tag

Community Treasure Hunt

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

Start Hunting!

Translated by