Hot News aus dem CAD.de-Newsletter:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  Lisp
  CSV-Daten einlesen

Antwort erstellen  Neues Thema erstellen
CAD.de Login | Logout | Profil | Profil bearbeiten | Registrieren | Voreinstellungen | Hilfe | Suchen

Anzeige:

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen nächster neuer Beitrag | nächster älterer Beitrag
Autor Thema:   CSV-Daten einlesen (350 mal gelesen)
cm-Zeichner
Mitglied
Vermessungstechniker


Sehen Sie sich das Profil von cm-Zeichner an!   Senden Sie eine Private Message an cm-Zeichner  Schreiben Sie einen Gästebucheintrag für cm-Zeichner

Beiträge: 130
Registriert: 23.07.2009

Win7Pro 64Bit, AutoCAD Map3D 2014 64Bit

erstellt am: 15. Feb. 2017 11:00    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Hallo zusammen,

habe eine CSV Datei mit folgendem Inhalt:

;346-60A1;;33585.11;321524.20;;;4091248.989;1233855.453;4719356.613;
05003;D1;;33216.26;321493.50;;;4091347.706;1233499.758;4719304.849;
05003;D2;;33236.40;321482.27;;;4091349.987;1233521.410;4719297.263;
usw.

möchte den Inhalt der einzelnen Zeilen nun "zerlegen" um diesen verschiedenen Variablen zuzuweisen.

für die erste Zeile würde das bedeuten:
VAR1 = leer
VAR2 = 346-60A1
VAR3 = leer
VAR4 = 33585.11
usw.

für die zweite Zeile:
VAR1 = 05003
VAR2 = D1
VAR3 = leer
VAR4 = 33216.26
usw.

Die Zeile auslesen schaffe ich noch

(setq zeile (read-line F))
(print zeile)

steht dann auch schön am Bildschirm nur beim Zerlegen javascript:InsertSMI(' %20');

Hat wer eine AUTOLISP-Lösung.
DANKE

------------------
Grüße Bernd

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

CADmium
Moderator
Maschinenbaukonstrukteur




Sehen Sie sich das Profil von CADmium an!   Senden Sie eine Private Message an CADmium  Schreiben Sie einen Gästebucheintrag für CADmium

Beiträge: 13244
Registriert: 30.11.2003

.

erstellt am: 15. Feb. 2017 11:14    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für cm-Zeichner 10 Unities + Antwort hilfreich

(defun DT:STR-DIVS(STRING SEPARATOR / POS OFFSET LISTE)
  (if(and(=(type STRING) 'STR)(=(type SEPARATOR) 'STR))
    (progn
      (setq POS    (vl-string-search SEPARATOR STRING))
      (setq OFFSET (1+(strlen SEPARATOR)))
      (while POS
        (setq LISTE  (cons (substr STRING 1 POS) LISTE)
              STRING (substr string (+ POS OFFSET))
              POS    (vl-string-search SEPARATOR STRING)
        )
      )
      (reverse (cons STRING LISTE))
    )
  )

(DT:STR-DIVS ";346-60A1;;33585.11;321524.20;;;4091248.989;1233855.453;4719356.613;" ";")
liefert dann
("" "346-60A1" "" "33585.11" "321524.20" "" "" "4091248.989" "1233855.453" "4719356.613" "")
oder gleich sowas
(mapcar 'set
        '(VAR1 VAR2 VAR3 VAR4 VAR5 VAR6 VAR7)
        (DT:STR-DIVS ";346-60A1;;33585.11;321524.20;;;4091248.989;1233855.453;4719356.613;" ";")
)

------------------
Also ich finde Unities gut ... und andere sicher auch
---------------------------------------
  - Thomas -          
"Bei 99% aller Probleme ist die umfassende Beschreibung des Problems bereits mehr als die Hälfte der Lösung desselben."

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

cm-Zeichner
Mitglied
Vermessungstechniker


Sehen Sie sich das Profil von cm-Zeichner an!   Senden Sie eine Private Message an cm-Zeichner  Schreiben Sie einen Gästebucheintrag für cm-Zeichner

Beiträge: 130
Registriert: 23.07.2009

Win7Pro 64Bit, AutoCAD Map3D 2014 64Bit

erstellt am: 15. Feb. 2017 11:37    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Danke für die schnelle Antwort,

aber ist für mich noch zu hoch.

Könntest Du es bitte auf mein Beispiel UMLEGEN.

Hab den Wert einer Zeile in der Variablen ZEILE gespeichert und das Trennzeichen der einzelnen Felder innerhalb der Zeile ist immer ein ";"
Dann rufe ich die zusätzliche Funktion "csv_zerlegen_ap" auf wo die "Zerlegung" und Zuweisung zu den einzelnen Variablen erfolgen soll. Das ginge irgendwie mit dem von Dir unten angeführten mapcar (glaub ich). Nachdem die Werte (auch "" möglich) den einzelnen Variablen zugewiesen wurden kehre ich wieder zum "Ausgansprogramm" zurück, mach dann dort was mit den Variablen, lese die nächste Zeile ein und starte von neuem.

Wie wäre Dein Code da zu ändern?

Danke nochmals.

------------------
Grüße Bernd

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

spider_dd
Mitglied



Sehen Sie sich das Profil von spider_dd an!   Senden Sie eine Private Message an spider_dd  Schreiben Sie einen Gästebucheintrag für spider_dd

Beiträge: 898
Registriert: 27.11.2003

Win7/64
ACAD 2014
C3D 2014
ET

erstellt am: 15. Feb. 2017 12:26    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für cm-Zeichner 10 Unities + Antwort hilfreich

Hallo Bernd,

übergib an den Aufruf der Funktion

DT:STR-DIVS einfach Deine Variable ZEILE als ersten Prameter.

Also etwa so

(DT:STR-DIVS Zeile ";")

HTH

Gruß
Thomas

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

cm-Zeichner
Mitglied
Vermessungstechniker


Sehen Sie sich das Profil von cm-Zeichner an!   Senden Sie eine Private Message an cm-Zeichner  Schreiben Sie einen Gästebucheintrag für cm-Zeichner

Beiträge: 130
Registriert: 23.07.2009

Win7Pro 64Bit, AutoCAD Map3D 2014 64Bit

erstellt am: 15. Feb. 2017 18:05    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Genau das war´s, Problem gelöst.
Danke 

------------------
Grüße Bernd

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Peter2
Ehrenmitglied V.I.P. h.c.




Sehen Sie sich das Profil von Peter2 an!   Senden Sie eine Private Message an Peter2  Schreiben Sie einen Gästebucheintrag für Peter2

Beiträge: 2833
Registriert: 15.10.2003

Win 7/64 Prof & Win 10/64 Pro
AutoCAD 2011 - 2017, Expresstools, VPRaster
BricsCAD V16

erstellt am: 15. Feb. 2017 20:15    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für cm-Zeichner 10 Unities + Antwort hilfreich

DosLIB bietet auch schöne Funktionen zum Daten einlesen und zerhacken ...
https://wiki.mcneel.com/doslib/home

------------------
Für jedes Problem gibt es eine einfache Lösung.
Die ist aber meistens falsch. ;-)

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Anzeige.:

Anzeige: (Infos zum Werbeplatz >>)

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen

nächster neuerer Beitrag | nächster älterer Beitrag
Antwort erstellen


Diesen Beitrag mit Lesezeichen versehen ... | Nach anderen Beiträgen suchen | CAD.de-Newsletter

Administrative Optionen: Beitrag schliessen | Archivieren/Bewegen | Beitrag melden!

Fragen und Anregungen: Kritik-Forum | Neues aus der Community: Community-Forum

(c)2017 CAD.de