WICHTIG: Der Betrieb von goMatlab.de wird privat finanziert fortgesetzt. - Mehr Infos...

Mein MATLAB Forum - goMatlab.de

Mein MATLAB Forum

 
Gast > Registrieren       Autologin?   

Partner:




Forum
      Option
[Erweitert]
  • Diese Seite per Mail weiterempfehlen
     


Gehe zu:  
Neues Thema eröffnen Neue Antwort erstellen

Inhalt einr cell eines cell-arrays spliten

 

FReef
Forum-Anfänger

Forum-Anfänger


Beiträge: 21
Anmeldedatum: 11.10.21
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 21.10.2021, 21:01     Titel: Inhalt einr cell eines cell-arrays spliten
  Antworten mit Zitat      
Hallo zusammen,

ich lade eine csv-Datei ein und lese dann eine bestimmte Spalte aus ("EyeVector").
Diese Spalte wird dann im workspace als cell-array gespeichert ca. 4000 x 1 cell.
Jede cell dieses arrays hat das Format
'(791.8442, 1071.698, 0.180000439)' entspricht '(x, y, z)'.
Wie schaffe ich es jetzt die einzelnen x,y,z-Werte auszulesen bzw. diese in einzelne Spalten umzuschreiben?

Mein Versuch war folgender, da wird mir aber nur die Anzahl der Einträge angezeigt mit numel, ich möchte aber die Werte in einzelnen Spalten haben und am besten noch benennen.
Code:

for k1 = 1:size(EyeVector,1)
r(k1,1) = numel(strsplit(EyeVector{k1}, ','));
end
 


Vielen Dank für eure Hilfe!!
Private Nachricht senden Benutzer-Profile anzeigen


Harald
Forum-Meister

Forum-Meister


Beiträge: 24.487
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 21.10.2021, 22:04     Titel:
  Antworten mit Zitat      
Hallo,

Code:
data = {'(2,3,4)', '(4,5,6)', '(791.8442, 1071.698, 0.180000439)'}'
data = erase(data, ["(", ")"])
str = cellfun(@(x) strsplit(x, ','), data, 'UniformOutput',false)
xyz = str2double(vertcat(str{:}))


Was meinst du mit "benennen"? Einen Table könntest du mit array2table erstellen.

Grüße,
Harald
_________________

1.) Ask MATLAB Documentation
2.) Search gomatlab.de, google.de or MATLAB Answers
3.) Ask Technical Support of MathWorks
4.) Go mad, your problem is unsolvable ;)
Private Nachricht senden Benutzer-Profile anzeigen
 
FReef
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 21
Anmeldedatum: 11.10.21
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 27.10.2021, 11:13     Titel:
  Antworten mit Zitat      
Hallo Harald,

ich habe versucht deinen Lösungsansatz einzuarbeiten, aber es klappt bisher noch nicht.
Ich werde daher versuchen mein Problem zu spezifizieren.

Innerhalb der csv-Datei ("main.csv") gibt es eine Spalte mit der Bezeichnung "Coordinates".
Diese lade ich wie folgt ein und bezeichne diese Daten mit "EyeVector"
Code:

data = readtable('main.csv', 'delimiter', {';'});
EyeVector = data.Coordinates;
 

"EyeVector" wird dann als cell-array mit 4000 x 1 cell dargestellt(Länge variiert).
Hier sind die ersten 20 Zeilen dargestellt:

    (791.8442, 1071.698, 0.180000439)
    (782.897339, 1071.361, 0.179999888)
    (446.312836, 280.857056, 0.122590482)
    (343.789368, 257.531647, 0.151678756)
    (446.2411, 247.34671, 0.17999959)
    (444.343384, 246.4827, 0.17999883)
    (792.622559, 197.900757, 0.179999143)
    (626.858032, 177.459518, 0.177910551)
    (611.2941, 175.900146, 0.17665121)
    (-Infinity, -Infinity, -Infinity)
    (-Infinity, -Infinity, -Infinity)
    (563.9459, 165.557571, 0.1680108)
    (609.814758, 226.214767, 0.178840309)
    (576.149231, 223.0222, 0.178842366)
    (602.765259, 225.449371, 0.178840935)
    (523.695557, 212.171021, 0.178842515)
    (546.9386, 213.0416, 0.179999053)
    (576.6753, 220.347717, 0.178842545)
    (404.9898, 231.946411, 0.173344374)
    (479.788452, 238.9744, 0.178839982)
    (489.315521, 287.493622, 0.179999039)


Jeder Eintrag entspricht dem Format (x, y, z).
Ziel ist ein Plot, wozu ich die x- & y-Werte benötige (scatplot).
Dieser wird über ein Hintergrundbild als eine Heatmap geplottet.

Wie schaffe ich es jetzt die x- & y-Werte in einzelne Spalten aufzuteilen?
Wie schaffe ich es zudem, dass die "infinity"-Zeilen gelöscht werden? Hier konnten keine Daten ermittelt werden.

Vielen Dank für die Hilfe.
Private Nachricht senden Benutzer-Profile anzeigen
 
FReef
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 21
Anmeldedatum: 11.10.21
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 27.10.2021, 12:43     Titel:
  Antworten mit Zitat      
Noch eine Ergänzung:
einige wenige Zeilen enthalten den Eintrag '-'.
Diese Zeilen muss ich auch löschen, sonst funktioniert die split-Funktion nicht mehr aufgrund fehlender delimiter.

Bisher habe ich das Einlesen wie folgt gelöst
Code:

data = readtable('main.csv', 'delimiter', {';'});
EyeVector = data.Coordinates;
EyeVector = EyeVector(1:20,1);
EyeVector = erase(EyeVector, ["(", ")"]);
EyeVector = split(EyeVector,',');

 
Private Nachricht senden Benutzer-Profile anzeigen
 
Harald
Forum-Meister

Forum-Meister


Beiträge: 24.487
Anmeldedatum: 26.03.09
Wohnort: Nähe München
Version: ab 2017b
     Beitrag Verfasst am: 27.10.2021, 19:20     Titel:
  Antworten mit Zitat      
Hallo,

am einfachsten wäre es, wenn du eine Beispieldatei zur Verfügung stellst. Dann kann man genau sehen, welche Probleme es z.B. aufgrund der Formatierung gibt.

Vor allem aber bitte immer dazu sagen, was "es klappt nicht" bedeutet. Bekommst du eine Fehlermeldung? Unerwartete Ergebnisse? Ich sehe erst mal nur, dass es in meinem Beispiel "klappt". Was nun in deinem Beispiel alles anders ist und warum es daher bei dir "nicht klappt", ist äußerst schwer zu erahnen.

Grüße,
Harald
_________________

1.) Ask MATLAB Documentation
2.) Search gomatlab.de, google.de or MATLAB Answers
3.) Ask Technical Support of MathWorks
4.) Go mad, your problem is unsolvable ;)
Private Nachricht senden Benutzer-Profile anzeigen
 
FReef
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 21
Anmeldedatum: 11.10.21
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 29.10.2021, 14:36     Titel:
  Antworten mit Zitat      
Danke für den Hinweis.

In Kurzform, da es eigentlich ein neues Thema ist...
Ich habe das:


    Vector
    791.8442, 1071.698, 0.180000439
    782.897339, 1071.361, 0.179999888
    446.312836, 280.857056, 0.122590482
    343.789368, 257.531647, 0.151678756
    446.2411, 247.34671, 0.17999959
    444.343384, 246.4827, 0.17999883
    792.622559, 197.900757, 0.179999143
    626.858032, 177.459518, 0.177910551
    611.2941, 175.900146, 0.17665121
    Infinity, Infinity, Infinity
    Infinity, Infinity, Infinity
    563.9459, 165.557571, 0.1680108
    609.814758, 226.214767, 0.178840309
    576.149231, 223.0222, 0.178842366
    -
    -
    546.9386, 213.0416, 0.179999053
    576.6753, 220.347717, 0.178842545
    404.9898, 231.946411, 0.173344374
    479.788452, 238.9744, 0.178839982
    489.315521, 287.493622, 0.179999039


und möchte das (beispielhaft für x, analog für y und z):

    x
    791.844
    782.897
    446.312
    343.789
    446.241
    444.343
    792.622
    626.858
    611.294
    NaN
    NaN
    563.945
    609.814
    576.149
    NaN
    NaN
    546.938
    576.675
    404.989
    479.788
    489.315


Das Problem sind die fehlenden delimiter ',' in den Zeilen mit "-".
Wie ersetze ich die Zeilen mit "-", damit ich am Ende auch ein NaN Eintrag bekomme?
Private Nachricht senden Benutzer-Profile anzeigen
 
FReef
Themenstarter

Forum-Anfänger

Forum-Anfänger


Beiträge: 21
Anmeldedatum: 11.10.21
Wohnort: ---
Version: ---
     Beitrag Verfasst am: 29.10.2021, 14:56     Titel:
  Antworten mit Zitat      
Ich mache dafür lieber ein neues Thema auf.
Bei meiner Suche habe ich bisher leider keine Lösung gefunden.
Danke erstmal.
Private Nachricht senden Benutzer-Profile anzeigen
 
Neues Thema eröffnen Neue Antwort erstellen



Einstellungen und Berechtigungen
Beiträge der letzten Zeit anzeigen:

Du kannst Beiträge in dieses Forum schreiben.
Du kannst auf Beiträge in diesem Forum antworten.
Du kannst deine Beiträge in diesem Forum nicht bearbeiten.
Du kannst deine Beiträge in diesem Forum nicht löschen.
Du kannst an Umfragen in diesem Forum nicht mitmachen.
Du kannst Dateien in diesem Forum posten
Du kannst Dateien in diesem Forum herunterladen
.





 Impressum  | Nutzungsbedingungen  | Datenschutz | FAQ | goMatlab RSS Button RSS

Hosted by:


Copyright © 2007 - 2024 goMatlab.de | Dies ist keine offizielle Website der Firma The Mathworks

MATLAB, Simulink, Stateflow, Handle Graphics, Real-Time Workshop, SimBiology, SimHydraulics, SimEvents, and xPC TargetBox are registered trademarks and The MathWorks, the L-shaped membrane logo, and Embedded MATLAB are trademarks of The MathWorks, Inc.