Effacer les filtres
Effacer les filtres

Structure fieldname Rename by referring a .csv column

7 vues (au cours des 30 derniers jours)
SOMASHEKAR M
SOMASHEKAR M le 12 Juin 2022
Commenté : Jan le 13 Juin 2022
Hi , I would like to rename the workspace structure fieldnames as per the desired names that are present in the column 2 of the .csv file.
The table looks like this
Fieldname DesiredName
____________ ____________
'Test_Sig0' 'Test_Sig_0'
'Test_Sig' 'Test_Sig_1'
'Junk_Sig' 'Junk'
'Junk_Sig_1' 'Junk1'
While structure looks like this
Test_Sig0: {3×2 cell}
Test_Sig: {3×2 cell}
As told earlier , I would like to replace the fieldname 'Test_Sig0' with Desired name referred from the csv, 'Test_Sig_0' and delete the fieldname 'Test_Sig0'.
  3 commentaires
SOMASHEKAR M
SOMASHEKAR M le 12 Juin 2022
I am able to import the table
Image Analyst
Image Analyst le 12 Juin 2022
I've removed your flag. What is unclear. If it's your question, then make it clear with better explanations (don't flag it). If it's one of the Answers, ask the person to explain better.

Connectez-vous pour commenter.

Réponses (1)

Jan
Jan le 12 Juin 2022
Import the table. Then:
Fieldname = {'Test_Sig0', 'Test_Sig', 'Junk_Sig', 'Junk_Sig_1'};
DesiredName = {'Test_Sig_0', 'Test_Sig_1', 'Junk', 'Junk1'};
S = RenameField(S, Fieldname, DesiredName)
  2 commentaires
SOMASHEKAR M
SOMASHEKAR M le 12 Juin 2022
Modifié(e) : Jan le 13 Juin 2022
I am quite new to MTALB , I have a long list of elements that has to be renamed and hence I am using the excel sheet to do it. Kindly refer the code below that I tried. Kindly recommend for changes based on the Excel reference only.
clear
clc
s.Test_Sig0={1,0.1;2,0.2;3,0.3};
s.Test_Sig1={1,0.1;2,0.2;3,0.3};
s.Junk_Sig_1={1,0.1;2,0.2;3,0.3};
save('temp.mat', '-struct', 's'); % Save fields to a .mat file
clear all % Clear local variables (just for display purposes)
s=load('temp.mat');
A=readtable('test_matrix.xlsx');
variables=A.Properties.VariableNames; %get variable names
B=fieldnames(s);
%B = struct2table(B);
out=[];
desired_ele=0;
for i=variables
myquery = 'CANName';
if ismember(myquery, A.Properties.VariableNames)
col = find(strcmp(myquery, A.Properties.VariableNames));
test=A(:,col);
test=table2array(test);
[val,pos]=intersect(test,B,'stable');
myquery = 'ModelName';
if ismember(myquery, A.Properties.VariableNames)
col = find(strcmp(myquery, A.Properties.VariableNames));
model=A(:,col);
model_test=table2array(model);
z=numel(pos);
end
end
%end
%end
end
% Append the Desired Element into the array
for j=1:numel(pos)
desired_ele=(model_test{pos})
end
%end
%Replace Ola Fieldname with New Fieldname
%matMap = matfile('temp.mat');
%s.Test_Sig_0 = s.('Test_Sig0'); % loop/repeat this for all varName fields
Jan
Jan le 13 Juin 2022
This is voodoo:
save('temp.mat', '-struct', 's'); % Save fields to a .mat file
clear all % Clear local variables (just for display purposes)
s=load('temp.mat');
clear all removes all loaded functions from the memory also and relaoding them fromthe slow disk is a massive waste of time.
I have posted a link to a function called RenameField already which does, what you want. Did you check it?
What is the purpose of this piece of code:
for j=1:numel(pos)
desired_ele=(model_test{pos})
end
desired_ele is overwritten in each iteration.
Does the posted code do, what you need or is there an open problem?

Connectez-vous pour commenter.

Catégories

En savoir plus sur Numeric Types 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