I'm trying to create 2 popup menus the first one stores all the 'Y numbers' and then depending on that I want to get the corressponding 'Version'. Note some Y numbers have more than 1 version. Hence I need help to figure it out

10 Kommentare

Rik
Rik am 31 Mär. 2020
As everything: try to slice up your problem into smaller problems you can solve. Into what parts could you cut this problem? Which of those is causing you issues to solve?
Dinouk Goonewardena
Dinouk Goonewardena am 31 Mär. 2020
firstly I already got the popumenu1 to store all my Y numbers, so now I need it to be able to depending on the Y number populate my popupmenu2 (2nd popupmenu) with the versions
Rik
Rik am 31 Mär. 2020
It looks like the ismember function would solve most of this problem.
Dinouk Goonewardena
Dinouk Goonewardena am 31 Mär. 2020
do you have a sample code for my case?
Rik
Rik am 31 Mär. 2020
Can you share sample data? That would make sure you can use my code directly and it would remove the need for me to create data from scratch or copy it from your screenshot.
Dinouk Goonewardena
Dinouk Goonewardena am 31 Mär. 2020
I'm using this data from an API which has a key and password aswell, which I cant share. If you can just make some radom data sets, I should be able to understand it
Rik
Rik am 31 Mär. 2020
Feel free to create some random data that has approximately the same characteristics as your real data. I don't need your actual data, just something similar to what you already shared in your screenshot.
Dinouk Goonewardena
Dinouk Goonewardena am 31 Mär. 2020
Bearbeitet: Dinouk Goonewardena am 31 Mär. 2020
Ynumber=[1;1;2;3;5];
Version={'AP'; 'AP_R' ;'AP' ;'TI1' ;'TI2'};
mytable= table(Ynumber,Version);
Rik
Rik am 31 Mär. 2020
Your code will generate a variable of the dataset class (which will apparently be removed in a future release), while your screenshot is of the table datatype. The data also doesn't look remotely similar to me. Should the first dropdown contain 0.1, 0.3, and 0.2, with the second dropdown containing only a single option after the first selection has been made?
Dinouk Goonewardena
Dinouk Goonewardena am 31 Mär. 2020
Bearbeitet: Dinouk Goonewardena am 31 Mär. 2020
A better example of data i guess, So the first 2 Y number (1) has 2 versions, which should be in the popupmenu2

Melden Sie sich an, um zu kommentieren.

Antworten (1)

Rik
Rik am 31 Mär. 2020

0 Stimmen

Ynumber=[1;1;2;3;5];
Version={'AP'; 'AP_R' ;'AP' ;'TI1' ;'TI2'};
mytable= table(Ynumber,Version);
%Y_selected=get(handles.dropdown_Y,'Value');
Y_selected=2;
selected_Ynumber=mytable.Ynumber(Y_selected);
L=ismember(mytable.Ynumber,selected_Ynumber);
versions=mytable.Version(L);
The last variable can be used as the String property of your second dropdown.

4 Kommentare

b = extractfield(data_sheet2,'Version');
popupMenuItems = get(handles.popupmenu1, 'String');
Y_selected = char(popupMenuItems{get(handles.popupmenu1,'Value')}); -----------(Error: Expected one output from a curly brace or dot indexing expression, but there were 12475 results.)
selected_Ynumber=data_sheet2.YNumber(Y_selected);
L=ismember(data_sheet2.YNumber,selected_Ynumber);
handles.popupmenu2.String=b(L);
I get an error for Y_selected, any idea of a fix for it?
Rik
Rik am 1 Apr. 2020
Yes, use the code I suggested. If your Ynumber column contains the items in your first dropdown, then the code I showed will work.
A more general rule of thumb: you are combining several steps in one line. Look at each step separately and try to determine if you expected those data types and sizes.
val=get(handles.popupmenu1,'Value');
item=popupMenuItems{val};
Y_selected = char(item);
Which of these lines is nog returning an error? Where is the data type different from what you expect?
Dinouk Goonewardena
Dinouk Goonewardena am 1 Apr. 2020
sorry not that line but this;
selected_Ynumber=data_sheet2.YNumber(Y_selected); -----------(Error: Expected one output from a curly brace or dot indexing expression, but there were 12475 results.)
L=ismember(data_sheet2.YNumber,selected_Ynumber);
handles.popupmenu2.String=b(L);
Rik
Rik am 1 Apr. 2020
The code I posted works. You can't send me the data you're working with, so you will have to provide example data that will reproduce the error. It seems like Y_selected might not be a scalar, or data_sheet2 is not a table or scalar struct.

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Variables finden Sie in Hilfe-Center und File Exchange

Produkte

Version

R2016b

Gefragt:

am 31 Mär. 2020

Kommentiert:

Rik
am 1 Apr. 2020

Community Treasure Hunt

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

Start Hunting!

Translated by