Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

CSV mit cmd auslesen

Frage Entwicklung Batch & Shell

Mitglied: GhostScripter

GhostScripter (Level 1) - Jetzt verbinden

28.08.2008, aktualisiert 18.10.2012, 8719 Aufrufe, 2 Kommentare

Hallo zusammen,

ich möchte eine CSV Datei (genauer ein NMEA Log) auslesen.

Das Problem ist, das je nach Empfang nicht alle Felder gefüllt werden sondern mehrere Kommata hintereinander stehen. Ich habe es mit einer FOR /F Schleife probiert, jedoch funktioniert das mit den "tokens=," nicht wie erwartet:

01.
for /F "delims=,. tokens=1,15" %%i in (%qfile%) do @( 
02.
  IF %%i==$GPRMC ( 
03.
    set datum=%%j 
04.
    goto weiter 
05.
06.
07.
:weiter
Und hier die interessierenden Sätze aus der NMEA Datei:
01.
$GPRMC,083342.622,V,,,,,,,050506,,*21 
02.
$GPRMC,083433.240,V,,,,,,,050506,,*20 
03.
$GPRMC,083434.240,V,,,,,,,050506,,*27 
04.
$GPRMC,083435.241,A,5724.0815,N,00529.2716,W,0.00,327.66,050506,,*1B 
05.
$GPRMC,083436.241,A,5724.0815,N,00529.2716,W,0.00,,050506,,*00 
06.
$GPRMC,083437.241,A,5724.0823,N,00529.2728,W,0.00,,050506,,*09 
07.
$GPRMC,083438.241,A,5724.0823,N,00529.2728,W,0.00,,050506,,*06 
08.
$GPRMC,083439.241,A,5724.0823,N,00529.2728,W,0.00,,050506,,*07 
09.
$GPRMC,083440.241,A,5724.0823,N,00529.2728,W,0.00,,050506,,*09 
10.
$GPRMC,083441.241,A,5724.0823,N,00529.2728,W,0.00,,050506,,*08 
11.
$GPRMC,083442.241,A,5724.0823,N,00529.2728,W,0.00,,050506,,*0B
Ich möchte die Zahlen 050506 (Datum) auslesen. In den ersten drei Zeilen bekomme ich mit "tokens=1,5" das richtige Ergebnis, in der vierten Zeile so wie im Script angegeben und danach wieder anders.

Die FOR Schleife zählt also aufeinanderfolgende Trennzeichen als eins.
Da ich nun schon seit 3 Tagen damit kämpfe, sehe ich wahrscheinlich den Wald vor lauter Bäumen nicht. Wenn mir also jemand auf die Sprünge helfen könnte...

Versuche mit der Powershell habe ich dann nach der Erkenntniss, das da noch ne Menge zu lernen ist aufgegeben.

Ich sach schonmal Danke und bis denn...
Mitglied: bastla
29.08.2008, aktualisiert 18.10.2012
Hallo GhostScripter und willkommen im Forum!

Ein verwandte Problemstellung hatten wir neulich hier - darauf aufbauend sollte etwa folgender Ansatz funktionieren:
01.
for /F "delims=" %%i in ('findstr /b /c:"$GPRMC" "%qfile%"') do set "Zeile=%%i" & call :ProcessLine 
02.
goto :eof 
03.
 
04.
:ProcessLine 
05.
set "Zeile=%Zeile:,,=,_,%" 
06.
set "Zeile=%Zeile:,,=,_,%" 
07.
for /f "tokens=10 delims=," %%a in ("%Zeile:,,=,_,%,") do set "datum=%%a" 
08.
echo %datum%
Grüße
bastla
Bitte warten ..
Mitglied: GhostScripter
29.08.2008 um 07:21 Uhr
Super, das ist es!

ich gebe zu, das mit dem Ersetzen hatte ich vorher noch nicht geschnallt. Genau das löst das Problem.


Beste Grüße
GhostScripter
Bitte warten ..
Ähnliche Inhalte
Batch & Shell
Netshare Batch aus CMD auslesen und in CSV erstellen
gelöst Frage von nowyouseeme93Batch & Shell13 Kommentare

Das bekomme ich aus cmd Befehl: Share name Resource Remark ADMIN$ C:\Windows Remote Admin IPC$ Remote IPC I$ I:\ ...

Windows Userverwaltung
Ordnergruppenfreigaben in CSV oder HTML auslesen
gelöst Frage von JafThomasWindows Userverwaltung3 Kommentare

Hallo zusammen, ich habe eine Excelliste eines Dienstleisters erhalten die mit den folgenden Daten unserer Fileserver gefüllt werden soll: ...

VB for Applications
CSV Datei mit VBS auslesen
Frage von scorpionesc83VB for Applications4 Kommentare

Hallo zusammen, ich bin in Sachen VBS ein totaler Anfänger und hoffe, dass ihr mir bei einem Problem helfen ...

Batch & Shell
Auslesen bestimmter Spalten aus csv
gelöst Frage von Berti82Batch & Shell6 Kommentare

Hallo, Ich bekomme regelmäßig csv-Dateien mit ca. 77 Spalten und prinzipiell unbegrenzten Zeilen. Diese muss ich eindampfen auf 5 ...

Neue Wissensbeiträge
Windows 10

Autsch: Microsoft bündelt Windows 10 mit unsicherer Passwort-Manager-App

Tipp von kgborn vor 1 TagWindows 106 Kommentare

Unter Microsofts Windows 10 haben Endbenutzer keine Kontrolle mehr, was Microsoft an Apps auf dem Betriebssystem installiert (die Windows ...

Sicherheits-Tools

Achtung: Sicherheitslücke im FortiClient VPN-Client

Tipp von kgborn vor 1 TagSicherheits-Tools

Ich weiß nicht, wie häufig die NextGeneration Endpoint Protection-Lösung von Fortinet in deutschen Unternehmen eingesetzt wird. An dieser Stelle ...

Internet

USA: Die FCC schaff die Netzneutralität ab

Information von Frank vor 2 TagenInternet5 Kommentare

Jetzt beschädigt US-Präsident Donald Trump auch noch das Internet. Der neu eingesetzte FCC-Chef Ajit Pai ist bekannter Gegner einer ...

DSL, VDSL

ALL-BM200VDSL2V - Neues VDSL-Modem mit Vectoring von Allnet

Information von Lochkartenstanzer vor 2 TagenDSL, VDSL2 Kommentare

Moin, Falls jemand eine Alternative zu dem draytek sucht: Gruß lks

Heiß diskutierte Inhalte
Batch & Shell
Kann man mit einer .txt Datei eine .bat Datei öffnen?
gelöst Frage von HelloWorldBatch & Shell20 Kommentare

Wie schon im Titel beschrieben würde ich gerne durch einfaches klicken auf eine Text oder Word Datei eine Batch ...

Router & Routing
OpenWRT bzw. L.E.D.E auf Buffalo WZR-HP-AG300H - update
gelöst Frage von EpigeneseRouter & Routing11 Kommentare

Guten Tag, ich habe auf einem Buffalo WZR-HP-AG300H die alternative Firmware vom L.E.D.E Projekt geflasht. Ich bin es von ...

LAN, WAN, Wireless
WLAN Reichweite erhöhen mit neuer Antenne
gelöst Frage von gdconsultLAN, WAN, Wireless8 Kommentare

Hallo, ich besitze einen TL-WN722N USB-WLAN Dongle mit einer richtigen Antenne. Ich frage mich jetzt ob man die Reichweite ...

Router & Routing
Fritzbox Gastnetz - exposed Host - zur Sophos IPTV
Frage von medikopterRouter & Routing7 Kommentare

Hallo zusammen, ich habe eine Frage bezüglich des Fritz box Gastzugangs an einer Sophos UTM Home. An liebsten wäre ...