How can I open a hyperlink from a button callback in AppDesigner?

5 visualizaciones (últimos 30 días)
I am creating an app where I would like to access information via an Edit field and a button. The user can write a specific number (system code) in the EditField and read information in a UITable below. For further reading I'd like to implement a button that calls the webpage where the PDF with additional information is stored. The links to the webpages regarding the selected code are stored as strings in an Excel file. So far I can access the right links as strings but I struggle to call the actual website. So far I have tried the "web" and "webpage" functions.
Initialization of public properties:
properties (Access = public)
links = readtable("guide_filling_code_neu_2.xlsx", 'Range', 'K1:K87','PreserveVariableNames', true);
codeguide = readtable("guide_filling_code_neu_2.xlsx", 'Range', 'A1:J87', 'PreserveVariableNames', true);
end
In the button callback function:
filling_code = app.SearchforfillingcodeEditField.Value;
r_1 = ismember(app.codeguide.('Filling Code'),filling_code); %Ermittlung der richtigen Reihe nach Eingabe
row = find(r_1);
linkstring = app.links(row,:);
linkstring = string(linkstring{:,:});
web(linkstring,'UniformOutput', false)
The execution brings the error
Error using web
Non-scalar in Uniform output, at index 1, output 1.
Set 'UniformOutput' to false.
Error in guide_filling_system/DetailsPDFButtonPushed (line 1445)
web(linkstring,'UniformOutput', false)
  2 comentarios
Fangjun Jiang
Fangjun Jiang el 16 de Feb. de 2024
Can you paste the value of linkstring when web() is executed? I am suprised by the error message because no output is needed.
Johannes
Johannes el 22 de Feb. de 2024
Yes I have tried that in a test script. value of linkstring is the URL as a string

Iniciar sesión para comentar.

Respuesta aceptada

Cris LaPierre
Cris LaPierre el 16 de Feb. de 2024
Editada: Cris LaPierre el 16 de Feb. de 2024
I get an error when using the command you shared
linkstring = 'https://www.mathworks.com';
web(linkstring,'UniformOutput', false)
Error using web
First argument must be text.
If I make the input argument a string, I do not.
web(linkstring,'UniformOutput', 'false')
However, I'm not sure you even need that name-value pair. At least, I can't find it documented for this function. Why not just use web(linkstring)?
One concern I would have is this code
linkstring = app.links(row,:);
linkstring = string(linkstring{:,:});
We can't see what your variable values are, but a url should not span multiple colums. If this is a workaround because your url is a character array, I suggest using the "TextType","string" option in readtable instead.
  5 comentarios
Johannes
Johannes el 22 de Feb. de 2024
Thank ypu for your answer. I tried the code without UniformOutput in a Test script using the mathworks-URL and it worked. So it must be something about the string I am trying to import from Excel. However, if I call the right cell from the table, the TextType does not make it a string. It`s still a 1x1 table.
Johannes
Johannes el 22 de Feb. de 2024
Editada: Johannes el 22 de Feb. de 2024
I have just found my error. The find function does not return anything, so the table is empty. This is because my input field is a text field and the numbers compared in the Excel file are doubles. Str2double fixed the issue.
filling_code = str2double(app.SearchforfillingcodeEditField.Value);
r_1 = ismember(app.codeguide.('Filling Code'),filling_code); %Ermittlung der richtigen Reihe nach Eingabe
row = find(r_1);
linkstring = app.links(row,:);
linkstring = linkstring{1,1};
web(linkstring)

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Data Type Conversion en Help Center y File Exchange.

Productos


Versión

R2023a

Community Treasure Hunt

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

Start Hunting!

Translated by