Converting Alternative Scientific Notation to MATLAB
5 views (last 30 days)
Show older comments
I have a file with these example numbers I have imported as strings. I can't import as numbers because they come up as NaN.
-5.769-2
3.9984-2
4.568450
These are the 3 variations of numbers in the file
I want to convert these imported strings to MATLAB double, but I get NaN for the first 2 variations.
str2double('-5.769-2') = NaN
str2double('3.9984-2') = NaN
str2double('4.568450') = 4.568450
I want to get the following
-5.769-2 = -5.769e-2
3.9984-2 = 3.9984e-2
Thanks for your assistance.
4 Comments
James Tursa
on 17 Nov 2020
You haven't answered my question about spacing. Are the numbers right next to each other, each in 8 columns exactly? Or ...? Can you post a sample of the lines? This would affect how people would answer your question.
Accepted Answer
Walter Roberson
on 17 Nov 2020
format long
S = {
'-5.769-2'
'3.9984-2'
'4.568450'
};
str2double(regexprep(S, '([-+]\d+)$', 'e$1'))
More Answers (0)
See Also
Categories
Find more on Data Type Conversion in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!