Effacer les filtres
Effacer les filtres

dlmread with ^ as delimiter

2 vues (au cours des 30 derniers jours)
wesso Dadoyan
wesso Dadoyan le 28 Juin 2015
Modifié(e) : dpb le 28 Juin 2015
Hi, Attached a text file where the ^ delimiter works well to import it to excel. The automatic import tab in matlab is failing to import it . I tried also the dlmread function using '^' as a delimiter but it didn't work. Any help is appreciated
  4 commentaires
wesso Dadoyan
wesso Dadoyan le 28 Juin 2015
I reattached the file.sorry for the inconvenience
wesso Dadoyan
wesso Dadoyan le 28 Juin 2015
Modifié(e) : dpb le 28 Juin 2015
for example using dlmread('bhcf0003.txt','^') led to the following error:
Error using dlmread (line 138)
Mismatch between file and format string.
Trouble reading number from file (row 1u, field 1u) ==>
rssd9999^rssd9001^BHCK0081^BHCK0395^BHCK0397^BHCK1350^BHCK2122^BHCK3123^BHCK3128^BHCK2125^BHCK2145^BHCK2150^BHCK2130^BHCK2155^BHCK3164^BHCK3163^BHCK2160^BHCK2170^BHDM6631^BHDM6636^BHFN6631^BHFN6636^BH
Error in Step1ReadCallReports (line 2)
dlmread('bhcf0003.txt','^')
also the automatic import didn't have the desired values (look at the difference between excel and matlab and the attached snapshots)

Connectez-vous pour commenter.

Réponses (2)

dpb
dpb le 28 Juin 2015
Modifié(e) : dpb le 28 Juin 2015
"Trouble reading number from file (row 1u, field 1u) ==>rssd9999^rssd9001^BHCK0081^BHCK0395^..."
>> help dlmread
dlmread Read ASCII delimited file.
RESULT = dlmread(FILENAME) reads numeric data from the ASCII
delimited file FILENAME. The delimiter is inferred from the formatting
of the file.
...
All data in the input file must be numeric. dlmread does not operate
on files containing nonnumeric data, even if the specified rows and
columns for the read contain numeric data only.
You can't read the file with dlmread per the doc above; it must be numeric data only. Use textscan
ADDENDUM
OK, w/ more info on the file that that's a header line, if you have recent release of Matlab, try readtable instead. It should figure out the number of elements/record automagically.
  3 commentaires
Walter Roberson
Walter Roberson le 28 Juin 2015
The column headers are stored in the file, right? dlmread() cannot handle text anywhere in the file.
dpb
dpb le 28 Juin 2015
That IS nonumeric data in the file; reread the help...

Connectez-vous pour commenter.


Jan
Jan le 28 Juin 2015
DataStr = fileread('bhcf0003.txt');
DataCell = regexp(DataStr, '\^', 'split');
Now you have a cell string: {'rssd9999', 'rssd9001', 'BHCK0081', ...}
  1 commentaire
wesso Dadoyan
wesso Dadoyan le 28 Juin 2015
I obtained 1x2561266 cell array. I have too many files like this where each row should correspond to a firm. It is very confusing to extract the data related to a specific firm from this cell array. All what I am wondering about is how to read in matlab the text file that I sent the way excel reads it.

Connectez-vous pour commenter.

Catégories

En savoir plus sur Large Files and Big Data dans Help Center et File Exchange

Produits

Community Treasure Hunt

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

Start Hunting!

Translated by