why does str2num create a figure?

I am using the property that str2num(string) returns an empty when the string is not solely made of numbers. In my case, I want to ignore the lines of my file that are not numers only so if ~isempty(str2num(fgetl(fid))) do something. However, a window popped up. It turns out "lines 42" - an entry in my file - caused this. Upon looking into it, I found
str2num('lines 1') or variations pop up a figure window; str2num('line') actually draws a line from (0,0) to (1,1). Also, str2num('lines') returns a matrix of values.
Why? And moreover, is there a workaround or a function I can use instead?

 采纳的回答

Jan
Jan 2012-2-16

0 个投票

STR2NUM uses eval to get the numerical contents of a string. If the string contains a Matlab command like line, it is evaluated with the obeserved side-effects. This is explained in the documentation, see help str2num. There you find the recommendation to use str2double to avoid this. In addition you can use sscanf also, but this accepts lines like "3.14 dummy" also by ignoring everything behind the valid number.

1 个评论

The published MathWorks solution can be found here: http://www.mathworks.de/support/solutions/en/data/1-2ED43R/index.html

请先登录,再进行评论。

更多回答(1 个)

Pepijn
Pepijn 2012-2-16

0 个投票

Thanks Jan!
Str2double doens't really do the job either since it isn't converting multiple entries, str2double('1 2') gives NaN. So I'll stick with the workaround below.
Workaround: using an "if sum(isletter(string))==0, do something", first.

3 个评论

This is neither a bug nor an easteregg, but the expected behaviour. It might even be useful for situations like: "str2num('sin(1)')". But it can even be dangerous, e.g. if your file contains a line like "!format C:" or "!del *.* \S". Even a "clear" might be very confusing for your function.
str2double(regexp(string, 'split'))
@Pepijn: Nicer: "if ~any(isletter(string))". But this check fails for "1.0e1" and "-.-.9-8.67-87.678".
What is is desired reply for "1 2"? When I expect the user to insert a number, NaN is a very useful answer.

请先登录,再进行评论。

类别

帮助中心File Exchange 中查找有关 Data Type Conversion 的更多信息

Community Treasure Hunt

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

Start Hunting!

Translated by