Using Eval function with string inside it?

29 vues (au cours des 30 derniers jours)
Jonathan
Jonathan le 9 Oct 2011
Modifié(e) : Stephen23 le 19 Juin 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

Réponse acceptée

Walter Roberson
Walter Roberson le 9 Oct 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 commentaire
Jonathan
Jonathan le 9 Oct 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

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur Variables dans Help Center et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by