Ich habe .csv
eine Datei in Notepad++, die Daten wie diese enthält:
1-6-2018,"(101)","","Sale",-862.96,,
"(Sale)",,837.96,
,"Diesel",12.000 Ltr,69.83/Ltr,837.96,
"Sales @ 5%",,23.80,
,"Polishing Cloth",1 Pcs,23.80/Pcs,23.80,
"CGST @ 2.5%",,0.60,
"SGST @ 2.5%",,0.60,
"(No. :16532)",
1-6-2018,"(149)","","Sale",-3212.18,,
"Sales(Sale)",,3212.18,
,"Diesel",46.000 Ltr,69.83/Ltr,3212.18,
"(No. :16533)",
// and many more
Wie kann ich in Notepad++ Suchen und Ersetzen (oder eine andere Methode) verwenden, um alle Zeilen zusammenzuführen, die nicht mit einem Datum beginnen, sodass das Endergebnis so aussieht?
1-6-2018,"(101)","","Sale",-862.96,,"(Sale)",,837.96,,"Diesel",12.000 Ltr,69.83/Ltr,837.96,"Sales @ 5%",,23.80,,"Polishing Cloth",1 Pcs,23.80/Pcs,23.80,"CGST @ 2.5%",,0.60,"SGST @ 2.5%",,0.60,"(No. :16532)",
1-6-2018,"(149)","","Sale",-3212.18,,"(Sale)",,3212.18,,"Diesel",46.000 Ltr,69.83/Ltr,3212.18,"(No. :16533)",
Jede Zeile, die nicht mit einem Datum beginnt, wird mit der vorherigen zusammengeführt...
Antwort1
- Ctrl+H
- Finde was:
\R(?!\d{1,2}-\d{1,2}-\d{4})
- Ersetzen mit:
LEAVE EMPTY
- check Umwickeln
- check Regulärer Ausdruck
- Replace all
Erläuterung:
\R : any kind of linebreak
(?! : start negative look ahead, make sure we don't have after:
\d{1,2} : 1 or 2 digits
- : a dash
\d{1,2} : 1 or 2 digits
- : a dash
\d{4} : 4 digits
) : end lookahead (ie. a date)
Ergebnis für gegebenes Beispiel:
1-6-2018,"(101)","","Sale",-862.96,,"(Sale)",,837.96,,"Diesel",12.000 Ltr,69.83/Ltr,837.96,"Sales @ 5%",,23.80,,"Polishing Cloth",1 Pcs,23.80/Pcs,23.80,"CGST @ 2.5%",,0.60,"SGST @ 2.5%",,0.60,"(No. :16532)",
1-6-2018,"(149)","","Sale",-3212.18,,"Sales(Sale)",,3212.18,,"Diesel",46.000 Ltr,69.83/Ltr,3212.18,"(No. :16533)",