Borrar filtros
Borrar filtros

Excel file with three columns and compare the data

3 visualizaciones (últimos 30 días)
stelios loizidis
stelios loizidis el 9 de Abr. de 2019
Editada: Adam Danz el 15 de Abr. de 2019
Hellow,
I have an excel file with three columns (visitors,lacation,score). I want to find out which visitors went to the same location and what score they made.
Code I wrote:
for j=1:locations
if (visitors(j)~=0 & locations(j)~=0)
flag=1;
score= score + abs(visitors9j0-locations(j))
end
if flag==1
score
else
string("no similarity")
end
end
  5 comentarios
stelios loizidis
stelios loizidis el 9 de Abr. de 2019
I entered the data as follows:
visitors=xlsread("data.xlsx","A1:A100")
locations=xlsread("data.xlsx","B1:B100")
scores=xlsread("data.xlsx","C1:C100")
e.g: locations(100X1):
locations.JPG
Adam Danz
Adam Danz el 9 de Abr. de 2019
Ok, that's clear. I still have 1 more quesiton.
"I want to find out which visitors went to the same location and what score they made."
Does that mean that 1) you want to choose a location (eg: # 70) and then list all visitors who went to that location and their scores or 2) for all locations, you want a list of visitors who have been there?
Also, how do you want this formatted? In a table? a cell array? It would be helpful for you to share an example of your desired output.

Iniciar sesión para comentar.

Respuestas (1)

Adam Danz
Adam Danz el 9 de Abr. de 2019
Editada: Adam Danz el 11 de Abr. de 2019
"I want to find out which visitors went to the same location and what score they made."
There are several ways to interpret this and several ways how to organize the data. Here are two interpretations.
% visitorNum: [n x 1] vector; numeric
% location: [n x 1] vector; numeric
% score: [n x 1] vector; numeric
% If you want to list all users who have been to location 3, and their scores (in a table)
targetLocation = 3;
locIdx = location == targetLocation;
table(visitorNum(locIdx), score(locIdx), 'VariableNames', {'Visitor', 'Score'})
% If you want to apply this to all locations, loop through each location and store each table
% in a cell array.
unqLocations = unique(location);
tbls = cell(size(unqLocations));
for i = 1:length(unqLocations)
locIdx = location == unqLocations(i);
tbls{i} = table(visitorNum(locIdx), score(locIdx), 'VariableNames', {'Visitor', 'Score'});
end
% tbls{x} is a table associated with location unqLocations(x)
  4 comentarios
stelios loizidis
stelios loizidis el 9 de Abr. de 2019
Okay, I tried what you said and worked just fine.
Thank you very much for the help!!!!
Adam Danz
Adam Danz el 9 de Abr. de 2019
Editada: Adam Danz el 15 de Abr. de 2019
Ok, glad it worked out - no problem.

Iniciar sesión para comentar.

Etiquetas

Community Treasure Hunt

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

Start Hunting!

Translated by