www.vorhilfe.de
Vorhilfe

Kostenlose Kommunikationsplattform für gegenseitige Hilfestellungen.
Hallo Gast!einloggen | registrieren ]
Startseite · Forum · Wissen · Kurse · Mitglieder · Team · Impressum
Forenbaum
^ Forenbaum
Status Englisch
  Status Grammatik
  Status Lektüre
  Status Korrekturlesen
  Status Übersetzung
  Status Sonstiges (Englisch)

Gezeigt werden alle Foren bis zur Tiefe 2

Navigation
 Startseite...
 Neuerdings beta neu
 Forum...
 vorwissen...
 vorkurse...
 Werkzeuge...
 Nachhilfevermittlung beta...
 Online-Spiele beta
 Suchen
 Verein...
 Impressum
Das Projekt
Server und Internetanbindung werden durch Spenden finanziert.
Organisiert wird das Projekt von unserem Koordinatorenteam.
Hunderte Mitglieder helfen ehrenamtlich in unseren moderierten Foren.
Anbieter der Seite ist der gemeinnützige Verein "Vorhilfe.de e.V.".
Partnerseiten
Weitere Fächer:

Open Source FunktionenplotterFunkyPlot: Kostenloser und quelloffener Funktionenplotter für Linux und andere Betriebssysteme
Forum "Matlab" - Cell-Funktionen
Cell-Funktionen < Matlab < Mathe-Software < Mathe < Vorhilfe
Ansicht: [ geschachtelt ] | ^ Forum "Matlab"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien

Cell-Funktionen: Idee/Hilfe
Status: (Frage) beantwortet Status 
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

        
Bezug
Cell-Funktionen: Antwort
Status: (Antwort) fertig Status 
Datum: 10:44 Mi 25.07.2007
Autor: funtaonice

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

Bezug
Ansicht: [ geschachtelt ] | ^ Forum "Matlab"  | ^^ Alle Foren  | ^ Forenbaum  | Materialien


^ Seitenanfang ^
www.englischraum.de
[ Startseite | Forum | Wissen | Kurse | Mitglieder | Team | Impressum ]