Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

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

Wie csv Datei mit Kommas in den Daten per RegExp verarbeiten?

Frage Entwicklung Perl

Mitglied: Farbauti

Farbauti (Level 1) - Jetzt verbinden

19.07.2012 um 10:14 Uhr, 4272 Aufrufe, 2 Kommentare

Hallo,

ich möchte CSV Dateien mit Regulären Ausdrücken verarbeiten.
Hauptsächlich verlasse ich mich darauf, dass nach dem x.ten Komma, die x.te Spalte ist.
Das klappt aber nicht immer.

Die Herausfoderung ist nun, dass es auch Spalten im CSV gibt, die selbst (ein oder mehrere) Kommas enthalten und mit " maskiert sind.

Ein
/^[^,]*,[^,]*,Treffer/
findet so meistens das Wort "Treffer" in der 3. Spalte.
Aber nicht, wenn die Zeile so aussähe:
123,"dies,das",Treffer,weiter
da hier das Komma im Text dazwischenfunkt.

Ich habe nun schon mit lookaheads und lookbehinds probiert, Kommas zwischen Hochkommas einfach durch Punkte zu ersetzen:
s/((?<=,")[^",]*),([^",]*(?=",))/\$1.\$2/g
das klappt zwar gut für genau 1 Komma, nicht aber für 2+ Kommas in einem Hochkomma-Text.

Hat jemand sowas schonmal gemacht, und kann mir ggf. eine funktionierende RegExp nennen?


viele Grüße, Farbauti.
Mitglied: bytecounter
19.07.2012 um 10:27 Uhr
Hallo,

ganz so einfach klappt das auch leider nicht, denn Dein Script müsste theoretisch alle Kommata, die in Anführungszeichen stehen, ignorieren.

Warum nutzt Du denn nicht einfach Text::CSV aus dem CPAN? Das wäre doch viel einfacher.

vg
Bitte warten ..
Mitglied: Farbauti
19.07.2012 um 11:48 Uhr
Ich wollte es nice & simple halten, weil das Script auf verschiedene Rechner deployed werden soll, wo ich nicht weiß, welche Module dort installiert sind.

Ich habe mittlerweile eine akzeptable Lösung selbst gefunden:
s/,(?=[^"]+?(",|"$))/./g

Das ersetzt mir alle Kommas, die vor einem Hochkomma stehen, welches ein Stringende anzeigt (", oder am Zeilenende).

Grüße, Farbauti.
Bitte warten ..
Ähnliche Inhalte
VB for Applications
Einzelne daten aus verschiedenen csv dateien in eine excel zusammenfügen (4)

Frage von K1200R zum Thema VB for Applications ...

Batch & Shell
gelöst Dateien aus CSV mit Batch suchen (5)

Frage von joes1609 zum Thema Batch & Shell ...

Batch & Shell
gelöst Skript für: Automatisch generierte CSV Datei (3)

Frage von janelsaesser zum Thema Batch & Shell ...

Microsoft
gelöst PowerShell: CSV in CSV kopieren (3)

Frage von Pludan zum Thema Microsoft ...

Neue Wissensbeiträge
Multimedia

Raspberry Pi als Digital-Signage-Computer

Information von BassFishFox zum Thema Multimedia ...

Windows Update

Novemberpatches und Nadeldrucker bereiten Kopfschmerzen

(15)

Tipp von MettGurke zum Thema Windows Update ...

Windows 10

Abhilfe für Abstürze von CDPUsersvc auf Win10 1607 und 2016 1607

(7)

Tipp von DerWoWusste zum Thema Windows 10 ...

Heiß diskutierte Inhalte
Router & Routing
Freigabe aus anderem Netz nicht erreichbar (21)

Frage von McLion zum Thema Router & Routing ...

Windows Server
Kennwort vergessen bei Hyper vserver 2012r (20)

Frage von jensgebken zum Thema Windows Server ...

Batch & Shell
Batch Programm verhalten bei shoutdown -p (19)

Frage von Michael-ITler zum Thema Batch & Shell ...

Festplatten, SSD, Raid
Raidcontroller funktioniert nur, wenn unter Legacy-Boot gestartet wird (13)

Frage von DerWoWusste zum Thema Festplatten, SSD, Raid ...