read binary text from a file and add zeros to it

조회 수: 1 (최근 30일)
Hadeel
Hadeel 2022년 9월 11일
댓글: Hadeel 2022년 9월 11일
Please. I need to read binary text from a file and if it is not a multiple of a certain number, add zeros to te until it becomes a multiple of it,iam do tracing to my code and i discover that the statment a=......... in while loop donot change its value based on the new text,it remain on the first text.
text = fileread('text1.txt');
n=input('enter the length of segment: ');
a=mod(length(text),n);
if a~=0
while a~=0
text=string(text)+"0";
a=mod(length(text),n);
end
end

채택된 답변

Image Analyst
Image Analyst 2022년 9월 11일
You forgot to attach the file!
If the text is binary like 0s and 1s, maybe try this
b = logical(readmatrix('text1.txt'));
% Make the vector 500000 elements long by padding zeros.
b(5000000) = false;
If you have any more questions, then attach your data with the paperclip icon after you read this:

추가 답변 (2개)

Walter Roberson
Walter Roberson 2022년 9월 11일
if a~=0
text = [text, repmat('0',1,n-a)];
end
Your bug is that you are converting text to string() array, but length() of a string array is the number of strings in the array, not the number of characters in the entry. See also strlength()

dpb
dpb 2022년 9월 11일
이동: Image Analyst 2022년 9월 11일
What's the form of the file -- just a string of 0s and 1s? if so then it would be simply something like
text = fileread('text1.txt');
N=input('enter the length of segment: ');
text=strcat(text,'0',repmat(1,N-strlength(text)));
if N > strlength(text), thanee it will add enough '0' to make up N overall; repmat will silengly do nothing if the repeat count is <=0 so you don't need any other logic outside; it's all handled internally ("magic happens").
fileread returns a char() vector to begin with so there's no conversion required there, either.
  댓글 수: 3
Walter Roberson
Walter Roberson 2022년 9월 11일
User wants output to be a multiple of N long rather than padding <N to N and leaving >N unchanged
Hadeel
Hadeel 2022년 9월 11일
thanks for your answer.the matters became ok

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Matrix Indexing에 대해 자세히 알아보기

제품


릴리스

R2019b

Community Treasure Hunt

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

Start Hunting!

Translated by