Datei zeilenweise auslesen, die Zeile Splitten und die Werte in mehrere Variablen schreiben
Hallo zusammen,
ich möchte eine Datei zeilenweise auslesen und die Daten, die durch Komma
getrennt sind in aufsteigenden Variablen ($m1,$m2....etc) speichern.
IF Open(3, @startdir + "\SETTINGS.INI") = 0
$x = ReadLine(3)
WHILE @16034 = 0
? "[" + $x + "]"
gosub "test"
$x = ReadLine(3)
LOOP
ENDIF
:test
debug on
$Myarray = Split("$x", ",")
For Each $x In $MyArray
? $x ; Zeigt die Werte die durch Komma
; getrennt sind
Next
Return
Hier bekomme ich nun die Wörter nacheinander angezeigt. Wie bekomme ich Sie
aber in die Austeigenden Variablen ?
Wenn also in der Datei stehen würde :
1. Zeile Max,Bernd,Thomas, ....etc
Dann möchte ich erhalten :
$m1 = Max
$m2 = Bernd
$m3 = Thomas ... etc
Die Daten würden dann verwendet und die nächste Zeile würde gelesen.
Vielen Dank im Voraus
Gruß Andreas
ich möchte eine Datei zeilenweise auslesen und die Daten, die durch Komma
getrennt sind in aufsteigenden Variablen ($m1,$m2....etc) speichern.
IF Open(3, @startdir + "\SETTINGS.INI") = 0
$x = ReadLine(3)
WHILE @16034 = 0
? "[" + $x + "]"
gosub "test"
$x = ReadLine(3)
LOOP
ENDIF
:test
debug on
$Myarray = Split("$x", ",")
For Each $x In $MyArray
? $x ; Zeigt die Werte die durch Komma
; getrennt sind
Next
Return
Hier bekomme ich nun die Wörter nacheinander angezeigt. Wie bekomme ich Sie
aber in die Austeigenden Variablen ?
Wenn also in der Datei stehen würde :
1. Zeile Max,Bernd,Thomas, ....etc
Dann möchte ich erhalten :
$m1 = Max
$m2 = Bernd
$m3 = Thomas ... etc
Die Daten würden dann verwendet und die nächste Zeile würde gelesen.
Vielen Dank im Voraus
Gruß Andreas
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 45268
Url: https://administrator.de/forum/datei-zeilenweise-auslesen-die-zeile-splitten-und-die-werte-in-mehrere-variablen-schreiben-45268.html
Ausgedruckt am: 20.05.2025 um 23:05 Uhr
4 Kommentare
Neuester Kommentar
Moin Andi101966,
willkommen im Forum.
Nicht weil es Sinn machen würde, sondern weil es ja Deine Frage war:
Test am CMD-Prompt:
Gruß
Biber
P.S. Die Floskel "Vielen Dank im Voraus" wird in diesem Zweig des Forums nicht so gern gelesen.
Auch wenn Du zu der Minderheit gehörst, die "voraus" mit einem "r" schreiben..
Mir sind Rückmeldungen lieber als Vorab-Danksagungen.
willkommen im Forum.
Nicht weil es Sinn machen würde, sondern weil es ja Deine Frage war:
; Tokentest.kix ...Demo zum Speichern von Arrayelementen m[1], m[2]...
; in Variablen $m1 , $m2 etc... (just for fun)
IF Open(3, @SCRIPTDIR +"\SETTINGS.txt") = 0
$x = ReadLine(3)
WHILE @ERROR = 0
? "Inhalt der Textdatei (aktuelle Zeile): [" + $x + "]"
gosub test
$x = ReadLine(3)
LOOP
ENDIF
Exit
:test
$mi = 1
$Myarray = Split("$x", ",")
For Each $x In $MyArray
$dummy = Execute('$$m'+ $mi +' = $x')
$mi = $mi + 1
Next
? "Zur Kontrolle: $$m1 :$m1. $$m2: $m2, $$m3: $m3, $$m4: $m4"
Return
Test am CMD-Prompt:
>kix32 TokenTest.kix
Inhalt der Textdatei (aktuelle Zeile): [Max,Bernd,Thomas,Biber]
Zur Kontrolle: $m1 :Max. $m2: Bernd, $m3: Thomas, $m4: Biber
Gruß
Biber
P.S. Die Floskel "Vielen Dank im Voraus" wird in diesem Zweig des Forums nicht so gern gelesen.
Auch wenn Du zu der Minderheit gehörst, die "voraus" mit einem "r" schreiben..
Mir sind Rückmeldungen lieber als Vorab-Danksagungen.
Moin Andi101966,
noch ein Nachtrag.
Wie gestern angedeutet halte ich es wirklich für einen Rückschritt (eigentlich sogar für eine Rolle rückwärts) von einer vorhandenden Arrayvariablen mit 100 Elementen wieder zurückzudrehen auf 100 Einzelvariablen mit einem Präfix ""$m" und einem Suffix von 1 bis 100.
Wenn ich es Dir schon nicht ausreden kann, dann mach das, was ich für Unsinn halte, wenigstens mit einer Funktion.
Test am CMD-Prompt mit Debugmeldungen:
Grüße
Biber
noch ein Nachtrag.
Wie gestern angedeutet halte ich es wirklich für einen Rückschritt (eigentlich sogar für eine Rolle rückwärts) von einer vorhandenden Arrayvariablen mit 100 Elementen wieder zurückzudrehen auf 100 Einzelvariablen mit einem Präfix ""$m" und einem Suffix von 1 bis 100.
Wenn ich es Dir schon nicht ausreden kann, dann mach das, was ich für Unsinn halte, wenigstens mit einer Funktion.
; Array2VarDemo.kix ...Demo zum Speichern von Arrayelementen m[1], m[2]...
; in GLOBALE Variablen $m1 , $m2 etc... (just for fun)
IF Open(3, @SCRIPTDIR +"\SETTINGs.txt") = 0
$x = ReadLine(3)
WHILE @ERROR = 0
? "[Debug]Inhalt der Textdatei (aktuelle Zeile): [" + $x + "]"
$RetVal= Array2Var(Split("$x", ","), "y")
? "[Debug] Zur m-Kontrolle: $$y1 :$y1. $$y2: $y2, $$y3: $y3, $$y4: $y4"
$x = ReadLine(3)
LOOP
ENDIF
Exit
Function Array2Var( $AnArray, $Prefix)
; schaufelt Elemente eines (eindimensionalen) Arrays unbesehen
; in GLOBALE Variablen mit angegebenem Prefix. $AnArray[i] assumed as Text (LTRIM).
For $i = 1 to Ubound($AnArray)+1
$Dummy = Execute( "Global $$"+ $prefix +$i)
$ExecuteStr = "$$"+ $prefix +($i) +'= "'+ LTrim($AnArray[$i-1]+'"')
? "[Debug] ExecuteStr: " $ExecuteStr
$Dummy = Execute($ExecuteStr)
Next
$Array2Var = (UBound($Array)>=0)
EndFunction
$cmd$kix32 Array2VarDemo.kix
[Debug]Inhalt der Textdatei (aktuelle Zeile): [Max, Bernd, Thomas, Biber]
[Debug] ExecuteStr: $y1= "Max"
[Debug] ExecuteStr: $y2= "Bernd"
[Debug] ExecuteStr: $y3= "Thomas"
[Debug] ExecuteStr: $y4= "Biber"
[Debug] Zur m-Kontrolle: $y1 :Max. $y2: Bernd, $y3: Thomas, $y4: Biber
Grüße
Biber
Moin Andy,
vielen Dank für die Rückmeldung und die gelieferten Hintergrund-Informationen.
So wie es sich für mich anhört, ist die von Dir angepeilte Prozess-Automatisierung ja durchaus sinnvoll und nachvollziehbar.
An ein oder zwei Stellen würde ich vielleicht noch mal (ggf. hier laut im Forum) darüber nachdenken,
ob denn KIX das geeignete Werkzeug für dieses Problem ist.
Bei denm ersten und dritten Zitat fiel mir sofort ein, dass VBSkript dieses wunderschöne Feature "CreateObject/GetObject(WischiWaschiApplikation)" hat.
Das heißt, mit VBSkript kannst Du zumindest die halbwegs dokumentierten M$-Office-Appz sozusagen "fremdsteuern" / von innen heraus bedienen per Skript, ohne dass da irgendetwas auf dem Bildschirm rumzappelt.
Beispiele für diese CreateObject(...Application) sind auch hier im Forum.
Ein kleines Tut "Automatisierte Mailverarbeitung.." von mir im Bereich "VB, VBS.." und auch ein oder zwei Beispiele zum Aufrufen des Internetexplorers über diesen Weg. Versuch es mal über Forumssuche.
Auch wenn du vielleicht mit VBSkript noch gar keine Berührungen hattest... ist halt nur ein anderer Dialekt.
An der groben Programmstrategie, die Du skizziert hast, ändert sich nicht soooo viel.
Im Zweifelsfall mach einen neuen Thread auf im Bereich "Entwicklung" und frage laut, welches Werkzeug/welche Skriptsprache am sinnvollsten verwendbar wäre.
Grüße
Biber
vielen Dank für die Rückmeldung und die gelieferten Hintergrund-Informationen.
So wie es sich für mich anhört, ist die von Dir angepeilte Prozess-Automatisierung ja durchaus sinnvoll und nachvollziehbar.
An ein oder zwei Stellen würde ich vielleicht noch mal (ggf. hier laut im Forum) darüber nachdenken,
ob denn KIX das geeignete Werkzeug für dieses Problem ist.
Da ich das auslesen eine Exceldatei über Kix nicht kenne,
Glaube auch nicht, dass Kix "direkt" so etwas kann..wollte ich aus der Exceldatei eine Textdatei mit Kommatrennung generieren.
Das wäre eigentlich auch -unabhängig vom verwendeten Werkzeug- mein Ansatz.Ich rufe aus Kix dann den Iexplorer samt generiertem Link auf, übergebe Benutzer und Passwort (sendkey)
Bei denm ersten und dritten Zitat fiel mir sofort ein, dass VBSkript dieses wunderschöne Feature "CreateObject/GetObject(WischiWaschiApplikation)" hat.
Das heißt, mit VBSkript kannst Du zumindest die halbwegs dokumentierten M$-Office-Appz sozusagen "fremdsteuern" / von innen heraus bedienen per Skript, ohne dass da irgendetwas auf dem Bildschirm rumzappelt.
Beispiele für diese CreateObject(...Application) sind auch hier im Forum.
Ein kleines Tut "Automatisierte Mailverarbeitung.." von mir im Bereich "VB, VBS.." und auch ein oder zwei Beispiele zum Aufrufen des Internetexplorers über diesen Weg. Versuch es mal über Forumssuche.
Auch wenn du vielleicht mit VBSkript noch gar keine Berührungen hattest... ist halt nur ein anderer Dialekt.
An der groben Programmstrategie, die Du skizziert hast, ändert sich nicht soooo viel.
Im Zweifelsfall mach einen neuen Thread auf im Bereich "Entwicklung" und frage laut, welches Werkzeug/welche Skriptsprache am sinnvollsten verwendbar wäre.
Grüße
Biber