Read notepad into a variable

Hi,
Id like to read a notepad file row and make that into a variable
txt{6}(1:end-1)=File(cals,txt{6}(1:end-1)); (says Conversion to char from struct is not possible)
I can run this command: txt{6}(1:end-1) and it would give me, ans="x"
i can also run A=File(cals,txt{6}(1:end-1)); and it would output a 1 by 1 structure with a value inside it.
Any suggetions?
Do i need to use eval? etc
Thank you!

7 comentarios

rockstar49
rockstar49 el 25 de Mayo de 2023
That is fine, is there a way to show this in the code?
Steven Lord
Steven Lord el 25 de Mayo de 2023
Can you attach a small sample file containing data representative of the data that you want to read into MATLAB and describe specifically how you want that data to be organized in MATLAB?
If the data was stored in a way that the file contains valid MATLAB code, the solution may be as straightforward as renaming the file from a .txt file to a .m file and running it.
Walter Roberson
Walter Roberson el 25 de Mayo de 2023
I suspect that rockstar used importdata() on a file that had a mix of text and numbers.
rockstar49
rockstar49 el 25 de Mayo de 2023
Editada: rockstar49 el 25 de Mayo de 2023
I can run this command: txt{6}(1:end-1) and it would give me, ans="x"
x would be a name like "animal"
in this example it shows
A=struct with fields:
Animals: 500
File(cals,txt{6}(1:end-1)); is only looking into numbers
Does this somewhat help?
Steven Lord
Steven Lord el 25 de Mayo de 2023
How did you create the variable named txt?
rockstar49
rockstar49 el 26 de Mayo de 2023
I used importdata (notepad file)

Iniciar sesión para comentar.

Respuestas (2)

Diwakar Diwakar
Diwakar Diwakar el 25 de Mayo de 2023
% Specify the path to the text file
filePath = 'path/to/your/file.txt';
% Read the text file
fileData = fileread(filePath);
% Split the file contents by newline character to get individual rows
rows = split(fileData, '\n');
% Select the desired row (in this example, row number 6)
rowIndex = 6;
selectedRow = rows{rowIndex};
% Display the selected row
disp(selectedRow);
% Store the selected row in a variable
myVariable = selectedRow;
You are trying to assign its value to the variable txt{6}(1:end-1) directly, which is causing the error. Try this code.

8 comentarios

rockstar49
rockstar49 el 25 de Mayo de 2023
Are you able to loop this? There are multiple rows in the notepad that i want to run through and assign it to the output of =File(cals,txt{6}(1:end-1));
for ex:
Animals=File(cals,txt{6}(1:end-1));
txt(6)= 1 by 1 cell array {' Animals;'}
dogs=File(cals,txt{7}(1:end-1));
Cats=File(cals,txt{8}(1:end-1));
txt(6)= 1 by 1 cell array {' Animals;'}
Walter Roberson
Walter Roberson el 25 de Mayo de 2023
Please show your code that creates File -- or if it is a function, please show us the code for the function.
rockstar49
rockstar49 el 26 de Mayo de 2023
The function files gets numeric values from a csv and writes it into the workspace
Walter Roberson
Walter Roberson el 26 de Mayo de 2023
The function File is returning a struct. We do not know what the fields of the struct look like.
I am also unclear as to what the desired outcome is.
I used importdata (notepad file)
Personally I avoid using importdata as the datatype it returns can depend upon the content of the file, so you have to check the class() of what it returns to figure out what kind of data the file happened to have.
Diwakar Diwakar
Diwakar Diwakar el 27 de Mayo de 2023
could you please show me sample of notepad file ?
rockstar49
rockstar49 el 27 de Mayo de 2023
Notepad is formatted like this etc
dogs;
cats;
horses;
cows;
Stephen23
Stephen23 el 27 de Mayo de 2023
Just use READCELLS or READLINES or similar.
Walter Roberson
Walter Roberson el 27 de Mayo de 2023
An example extract from the file would help.
As would a clearer description of what you are trying to do with the information.

Iniciar sesión para comentar.

Image Analyst
Image Analyst el 28 de Mayo de 2023
Try
textLines = readlines(fileName);
If you have any more questions, then attach your text file with the paperclip icon after you read this:

Categorías

Más información sobre File Operations en Centro de ayuda y File Exchange.

Productos

Versión

R2021a

Etiquetas

Preguntada:

el 25 de Mayo de 2023

Respondida:

el 28 de Mayo de 2023

Community Treasure Hunt

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

Start Hunting!

Translated by