Using Eval function with string inside it?

67 visualizaciones (últimos 30 días)
Jonathan
Jonathan el 9 de Oct. de 2011
Editada: Stephen23 el 19 de Jun. de 2019
Hi,
I use a lot of eval functions to run the same calculation on multiple files with similarly formatted names, and come across the following problem frequently:
for ii=1:4
var1=char(GLOBALS.Meta{ii,1});
eval([var1 '.APO_detr_Grid=griddata(' var1 '.SO_APO_detr(:,1),' var1 '.SO_APO_detr(:,2),' var1 '.SO_APO_detr(:,3),GLOBALS.XI,GLOBALS.YI, 'cubic');']);
end
clear ii var1;
Here, I'm trying to run multiple instances of the griddata function with a cubic interpolation, but because 'cubic' needs to be in quotes, it messes up the formatting of the eval function which used quotes to distinguish variables from the strings it's concatenating.
Is there such a thing as a character that suppresses the meaning of formatting symbols in this sort of case? Something like a & or $ or #? Or is there another way to do this? Or do I just have to work around the issue? For quick iterations this isn't a problem, but for larger datasets this becomes tedious writing every instance out individually.
Thanks!
Jonathan

Respuesta aceptada

Walter Roberson
Walter Roberson el 9 de Oct. de 2011
Please don't do that! Please see this FAQ
But to answer your question: to get a ' in a string, code two of them in a row, such as
',''cubic'');'
  1 comentario
Jonathan
Jonathan el 9 de Oct. de 2011
Thanks, Walter.
The '' trick is exactly what I needed for the present time, but I will eventually switch over to a system of pre-allocating and not using eval functions as much. I have some bad habits accumulated from years of putting off learning logical indexing... I'm in the process of changing a lot of my code to improve this.
If I can't sort out how to change over the the system described in the FAQ, I'll ask a follow-up.
Thanks,
Jonathan

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Variables en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by