フィルターのクリア

Effective way to extract rows (range) from a text file

3 ビュー (過去 30 日間)
Sultan
Sultan 2019 年 5 月 12 日
コメント済み: Jeremy Hughes 2019 年 5 月 15 日
I made a small loop to extract rows [range 183:262326] to make a column of 262144x1 column vector. The loop is very inefficient and takes a lot of time to execute. The code is below. Is there any more efficient way ? I dont want to use "Import Data" feature in MATLAB, I want to use code only.
fid=fopen('ABC.txt');
j=1;
for i=183:262326
linenum = i;
C(j,1) = textscan(fid,'%f',1,'delimiter','\n', 'headerlines',i-1);
j = j+1;
end
  2 件のコメント
Image Analyst
Image Analyst 2019 年 5 月 12 日
Maybe, but you forgot to attach abc.txt so we can't really help very effectively until you do. Maybe dlmread() or importdata() would do the trick, but we don't know until you attach the text file.
Sultan
Sultan 2019 年 5 月 15 日
編集済み: Sultan 2019 年 5 月 15 日
Unfortunately the textfile "ABC.txt" is a very large file 25MB even compressing the file proved uselss. But I used the command dlmread() first then used readmatrix() as the former is now not recommended. readmatrix() extracted all the numeric data and output was numeric matrix.

サインインしてコメントする。

採用された回答

Sultan
Sultan 2019 年 5 月 15 日
Unfortunately, due to very large size of "ABC.txt" file, it could not be uploaded. However following the hints of both the commentors. I simply used readmatrix() to extract all the numeric data. The extraction is much efficient.
A = readmatrix('ABC.txt')

その他の回答 (1 件)

Jeremy Hughes
Jeremy Hughes 2019 年 5 月 12 日
Readling line by line is quite ineffecient.
Try this:
C = textscan(fid,'%f','delimiter','\n', 'headerlines',182);
  2 件のコメント
Sultan
Sultan 2019 年 5 月 15 日
It worked thanks alot, but it is limited to reading only a single row. My intention was to extract the entire column. The problem was solved using readmatrix().
Jeremy Hughes
Jeremy Hughes 2019 年 5 月 15 日
There must be something else in the file other than numbers that causes textscan to stop after the first number.
Glad you found a solution.

サインインしてコメントする。

カテゴリ

Help Center および File ExchangeText Files についてさらに検索

製品


リリース

R2019a

Community Treasure Hunt

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

Start Hunting!

Translated by