Borrar filtros
Borrar filtros

How can i call function without any output arguments?

11 visualizaciones (últimos 30 días)
Emir Dönmez
Emir Dönmez el 27 de Feb. de 2023
Comentada: Cris LaPierre el 27 de Feb. de 2023
On my project my code is working. After that i tried to add a funciton on my code. As you can see down below i put my codes in a funciton & called it "plotter" without any output arguments.
function plotter(files, dir_path)
Exceldir = dir_path + "\ExcelFiles";
cd(Exceldir); % Change current directory to the where excel files restored in.
for i=1:length(files)
% Get sheet names being in the excel file.
sheets = sheetnames(files(i).name); % Sheets array.
% Get whole datas inside the excel files month by month.
for j=1:length(sheets)
data = readtable(files(i).name, "Sheet", sheets(j));
days = 1:1:size(data.Date); % Days array.
hold on;
plot(data.number_sold, days, "b.", "LineWidth", 2) % xAxis = sold_number
% yAxis = days
end
end
hold off;
end
% Call function "plotter"
xlsx_files = dir("*.xlsx");
Maindir = "C:\Users\emird\AppData\Local\Programs\df_2_db";
plotter(xlsx_files, Maindir)
When i call my funciton i get an error.
How can solve this problem and run my code?
  7 comentarios
Stephen23
Stephen23 el 27 de Feb. de 2023
Editada: Stephen23 el 27 de Feb. de 2023
"When i run my code it changes current directory to where the excel files stored in(gets in the ExcelFiles directory)."
Which is one of the reasons why it is a bad idea to change directory just to access data files: your code changes the function scope.... and then functions don't work, because you have changed the function scope. Best avoided.
The recommended approach is to use absolute/relative filenames to access data files. All MATLAB functions that access data files accept absolute/relative filenames. You should use absolute/relative filenames. You will find FULLFILE useful for this.
Emir Dönmez
Emir Dönmez el 27 de Feb. de 2023
Okey thank you very much.

Iniciar sesión para comentar.

Respuestas (1)

Cris LaPierre
Cris LaPierre el 27 de Feb. de 2023
Editada: Cris LaPierre el 27 de Feb. de 2023
Based on the code you have shared, you likely need to change the order of your script. Functions must be defined at the bottom of the script.
% Call function "plotter"
xlsx_files = dir("*.xlsx");
Maindir = "C:\Users\emird\AppData\Local\Programs\df_2_db";
plotter(xlsx_files, Maindir)
function plotter(files, dir_path)
Exceldir = dir_path + "\ExcelFiles";
cd(Exceldir); % Change current directory to the where excel files restored in.
for i=1:length(files)
% Get sheet names being in the excel file.
sheets = sheetnames(files(i).name); % Sheets array.
% Get whole datas inside the excel files month by month.
for j=1:length(sheets)
data = readtable(files(i).name, "Sheet", sheets(j));
days = 1:1:size(data.Date); % Days array.
hold on;
plot(data.number_sold, days, "b.", "LineWidth", 2) % xAxis = sold_number
% yAxis = days
end
end
hold off;
end
  8 comentarios
Emir Dönmez
Emir Dönmez el 27 de Feb. de 2023
okey i get it. Thank you for everything.
Cris LaPierre
Cris LaPierre el 27 de Feb. de 2023
+1 to Stephen23's comment.

Iniciar sesión para comentar.

Productos

Community Treasure Hunt

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

Start Hunting!

Translated by