Cell-Funktionen < Matlab < Mathe-Software < Mathe < Vorhilfe
|
Status: |
(Frage) beantwortet | Datum: | 11:19 Di 24.07.2007 | Autor: | corschmi |
Aufgabe | Dateneinlesen mittels textread. benötigte Daten in eine Cell speichern und einen ASCII-output generieren. Anschließend gleiche Daten in eine andere Cell speichern, wobei nur bestimmte Zeilen und Spalten benötigt werden mit anschließender ASCII-output Generierung |
Ich habe diese Frage in keinem Forum auf anderen Internetseiten gestellt
Hallo,
in meinem Matlab-Programm habe ich mittels textread Daten eingelesen, die sowohl Zahlen als auch Text beinhalten.
Anschließend habe ich mir eine neue "Tabelle" gebaut mit help=cell(numberOfRows, NumberOfColumns) und die benötigten Daten aus dem Input dort reingeschoben. Das war mit einer FOR-Schleife kein Problem. Nun möchte ich die Daten einmal als txt-File Speichern, also im ASCII-Format. Leider habe ich das nicht hinbekommen, da in den Daten sowohl Zahlen als auch Text vorhanden ist. Alternativ habe ich jetzt xlswrite gemacht (aidaForMchips = xlswrite('aidaForMchips.xls', help)). Hat geklappt. Jetzt muß man Excel öffnen und dann alles als txt abspeichern, da ich hinterher einen ASCII-File brauche. Gibt es eine Lösung, direkt alles in einen ASCII-File zu speichern?
Beispiel help:
help:
0 0 0 0 prim/sec Name Integral [QL] Bkg [QL] mchips_ID
1 1 1 1 0 AR_WIZ 560.0 0.0 01_01_01_01
1 1 3 1 0 CTNNB1_WIZ 1007.0 0.0 01_01_03_01
1 1 5 1 0 IGFBP2_WIZ 1025.0 0.0 01_01_05_01
1 1 7 1 0 MKI67_WIZ 1892.0 312.0 01_01_07_01
1 1 9 1 0 RPL27_WIZ 18109.0 780.0 01_01_09_01
1 1 11 1 0 THBS2_WIZ 182.0 0.0 01_01_11_01
1 1 13 1 0 PLAT_WIZ 22.0 0.0 01_01_13_01
1 1 15 1 0 AP2B1_WIZ 6911.0 0.0 01_01_15_01
Mein zweites Problem ist, das ich meine "Tabelle" help jetzt unter einem anderen Namen abspeichern will, wobei die Informationen vermindert werden sollen. Sprich ich will die 1.Zeile nicht mehr haben (Zukunft: und später von 8 Spalten nur noch die Spalten 2,4,5 und 7). Ich habe einfach das Programm nochmal hinten drangehängt mit einer neuen help2=cell(numberOfRows,NumberOfColumns) und die Daten dort reingeschrieben. Man kann sagen, daß das Programm jetzt aus zwei identischen Blöcken besteht. Gibt es da nicht eine einfachere Lösung Spalten oder Zeilen in einer Cell zu löschen?
Beispiel help2 ohne 1.Zeile:
1 1 1 1 0 AR_WIZ 560.0 0.0 01_01_01_01
1 1 3 1 0 CTNNB1_WIZ 1007.0 0.0 01_01_03_01
1 1 5 1 0 IGFBP2_WIZ 1025.0 0.0 01_01_05_01
1 1 7 1 0 MKI67_WIZ 1892.0 312.0 01_01_07_01
1 1 9 1 0 RPL27_WIZ 18109.0 780.0 01_01_09_01
1 1 11 1 0 THBS2_WIZ 182.0 0.0 01_01_11_01
1 1 13 1 0 PLAT_WIZ 22.0 0.0 01_01_13_01
1 1 15 1 0 AP2B1_WIZ 6911.0 0.0 01_01_15_01
1 1 1 3 0 AZGP1_WIZ 79.0 0.0 01_01_01_03
Vielen Dank für die Hilfe,
Corinna
|
|
|
|
Moin,
1. Frage/Idee: Muss es unbedingt textread sein? Ich würde dafür eher textscan benutzen!
2. Willst/musst du nur zeilen oder auch spalten manipulieren?
Wenn Du nur zeilen manipulieren willst dann würde ich die Datei zeilenweise einlesen - in etwa so ({backslash} durch \ ersetzen!):
MatlabCode
fid = fopen('urfile.txt', 'r');
C = textscan(fid, '%s','delimiter','{backslash}n');
fclose(fid); MatlabCode
Dann hast Du auch bereits ein cellarray und musst ja "nur" das array manipulieren.
Um also die erste zeile zu löschen in etwa so:
MatlabCode
C=[C{1}(2:9)]; MatlabCode
Natürlich kannst du dann jede beliebige(n) zeile abspeichern für die zeilen 2,4,6 mal beispielhaft in etwa so:
MatlabCode
C=[C{1}(2);C{1}(4);C{1}(6)];
MatlabCode
Problem bei dieser vorgehensweise du kannst nur die zeilen vernünftig manipulieren!
Deswegen die eigentlich elegantere Möglichkeit:
MatlabCode
fid = fopen('test.txt', 'r');
C = textscan(fid, '%s %s %s %s %s %s %s %s %s %s %s');
fclose(fid); MatlabCode
Jetzt solltest du ein verschachteltes cellarray haben, das erste arry enthält die einzelnen spalten und jedes spaltenarray ein array mit den entsprechenden zeilen.
Tja und jetzt ist es nur deinem geschick mit arraymanipulationen überlassen die gewünschten inhalte zu bekommen. Mal so als kleines Beispiel - Spalten 5,7,8 mit den zeilen 2-9 werden in das cellarray übernommen:
MatlabCode
C=[C{5}(2:9),C{7}(2:9),C{8}(2:9)]; MatlabCode
Damit sollte man das array eigentlich beliebig manipulieren können, alles nur eine frage des geschicks!
Zum speichern in eine textdatei musst du das array vorher wieder in character/strings wandeln:
MatlabCode
C=char(C); MatlabCode
Um im ASCII-Code zu speichern musst du die datei ja nur im richtigen modus/format öffnen:
MatlabCode
fid = fopen('t.txt', 'w', 'n', 'ASCII'); MatlabCode
Um die ausgabe in der textdatei vernünftig zu formatieren würde ich Dir die funktion fprintf empfehlen.
regards
funtaonice
|
|
|
|