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

Zeilen zwischen zwei Werten ausgeben

Frage Entwicklung

Mitglied: Uppe

Uppe (Level 1) - Jetzt verbinden

27.10.2010 um 11:32 Uhr, 2805 Aufrufe, 7 Kommentare

Hallo,

ich habe eine Datei, die wie folgt aufgebaut ist:

Gruppe1

blabla
blublu

Textmarke1

wichtig1
wichtig2

wichtig3
wichtig4

Textmarke2

blibli
bloblo

Gruppe2

haha

hihi

Textmarke1

wichtig5

wichtig6
wichtig7

Textmarke2
usw

Ich brauche aus dieser Datei jeweils die Gruppe und alles was zwischen Textmarke1 und Textmarke2 steht. Das möchte ich in einer neuen Datei mit Semikolon getrennt in eine Zeile schreiben.

Ich kann die Datei zeilenweise einlesen und auch die Gruppe in die neue Datei schreiben. Aber wie muß ich nun weitermachen, dass die Zeilen zwischen den Textmarken direkt hinter die jeweilige Gruppe geschrieben werden?

Danke und Gruß Uppe

PS: Die Leerzeilen sind willkürlich und ich brauche sie nicht.


blublu
Mitglied: micneu
27.10.2010 um 11:37 Uhr
ein fall für sed und/oder awk

auf welchem system willst du es gelöst haben?
Bitte warten ..
Mitglied: Uppe
27.10.2010 um 11:57 Uhr
Hallo,

habe gerade mal nach sed und awk gegoogelt. Oh, oh, da steht mir ja was bevor! Ich habe bisher mit vbscript rumgedoktert.

Es sind Log-Dateien in einem Windows-Verzeichnis.

Gruß Uppe
Bitte warten ..
Mitglied: micneu
27.10.2010 um 12:16 Uhr
von welchem programm?
würde mir noch etwas helfen ein awk script zu schreiben.
bin schon dabei mit den daten die ich von dir habe
Bitte warten ..
Mitglied: Uppe
27.10.2010 um 12:32 Uhr
wie "von welchem Programm"? Es sind die Logdateien eines Legato Networkers.
Bitte warten ..
Mitglied: miniversum
27.10.2010 um 13:33 Uhr
Wenn du schon mit vbscript angefangen hast dann würde ich damit weiter machen.
Du kannst die Datei ja komplett einlesen, dan hast du siein einer Variabeln.
Dann kannst über die instr Funktion die Position von Gruppe1 und Gruppe2 suchen und mit der Mid Funktion alles dazwischen raussuchen. Danach machst du das gleiche nochmal mit Textmarke1 und Textmarke2.
Alternativ kanns du auch gleich beim zeilenweisen einlesen Das wegschreiben was du brauchst.
Dabei arbeitest du mit z.b. 2 Variabeln, InGruppe1 und InTextmarke1. Beid setzt zu auf 0.
InGruppe1 = 0
InTextmarke1 = 0
SchreibZeile = ""
Du liest in einer Schleife Zeile für Zeile ein (aktZeile).
In der Schleife machst du eine Abfrage für Gruppe1, Gruppe2, Testmarke1 und für Testmarke2.
If aktZeile = "Gruppe2" then InGruppe1 = 0
If aktZeile = "Textmarke2" then InTextmarke1 = 0
If InGruppe1 = 1 and InTextmarke1 = 1 then SchreibZeile = SchreibZeile & aktZeile & ";"
If aktZeile = "Textmarke1" then InTextmarke1 = 1
If aktZeile = "Gruppe1" then InGruppe1 = 1
Und nach der Schleife schreibst du dann SchreibZeile in eine Datei.
Bitte warten ..
Mitglied: bastla
27.10.2010 um 17:49 Uhr
Hallo Uppe!

Als VBS (ausgehend von der oben dargestellten Struktur) etwa so:
01.
Ein = "D:\Datei.txt" 
02.
Aus = "D:\Datei.csv" 
03.
Gruppe = "Gruppe" 
04.
Von = "Textmarke1" 
05.
Bis = "Textmarke2" 
06.
Delim = ";" 
07.
 
08.
Set fso = CreateObject("Scripting.FileSystemObject") 
09.
Set E = fso.OpenTextFile(Ein) 
10.
Set A = fso.CreateTextFile(Aus) 
11.
 
12.
LGr = Len(Gruppe) 
13.
Do Until E.AtEndOfStream 
14.
    ZEin = Trim(E.ReadLine) 'Leerzeichen vor und nach dem Text entfernen 
15.
    If ZEin <> "" Then 'keine Leerzeilen verarbeiten 
16.
        If Left(ZEin, LGr) = Gruppe Then 'Beginn Gruppe? 
17.
            ZAus = ZEin 'Ausgabzeile beginnt mit Gruppennamen 
18.
        ElseIf ZEin = Von Then 'Beginn "wichtiger" Bereich? 
19.
            InBereich = True 'Schalter setzen 
20.
        ElseIf ZEin = Bis Then 'Ende "wichtiger" Bereich? 
21.
            A.WriteLine ZAus 'Zeile in Datei schreiben 
22.
            InBereich = False 'Schalter rücksetzen 
23.
        ElseIf InBereich Then 'Zeile aus "wichtigem" Bereich? 
24.
            ZAus = ZAus & Delim & ZEin 'der Ausgabezeile (nach Trennzeichen) hinzufügen 
25.
        End If 
26.
    End If 
27.
Loop 
28.
A.Close
Annahmen:
  • Jede Gruppenbezeichnung beginnt mit "Gruppe" (siehe Zeile 3).
  • Jede Gruppe enthält genau einen "wichtigen" Teil.
  • Jeder "wichtige" Teil ist zuverlässig durch "Textmarke1" (= Von) und "Textmarke2" (=Bis) begrenzt.
  • Groß-/Kleinschreibung der Gruppennamen und Textmarken stimmen mit den Angaben in den Zeilen 3 bis 5 überein.
  • Leerzeichen an Beginn und Ende der Zeile dürfen entfernt werden, Leerzeilen fallen weg.

Grüße
bastla
Bitte warten ..
Mitglied: Uppe
27.10.2010 um 22:34 Uhr
Hallo bastla,

vielen Dank! Damit kann ich es für mich anpassen. Super!

Gruß Uppe
Bitte warten ..
Ähnliche Inhalte
Microsoft Office
gelöst Excel: Wert aus mehreren Zeilen vergleichen (2)

Frage von Nicolaas zum Thema Microsoft Office ...

Microsoft Office
gelöst Excel: Wenn Wert in Spalte A dann kopiere Zeile (8)

Frage von michi1983 zum Thema Microsoft Office ...

C und C++
Parsen eines Wertes zwischen zwei Tags (c++, xml) (1)

Frage von peterpa zum Thema C und C ...

Datenbanken
Mit sql eine Zeile einfügen, select und feste Werte (9)

Frage von helmuthelmut2000 zum Thema Datenbanken ...

Neue Wissensbeiträge
Viren und Trojaner

Ransomware or Wiper? RedBoot Encrypts Files but also Modifies Partition Table

Information von BassFishFox zum Thema Viren und Trojaner ...

Notebook & Zubehör

WOL bei HP Notebooks

(6)

Erfahrungsbericht von Henere zum Thema Notebook & Zubehör ...

LAN, WAN, Wireless

Neue Cisco Catalyst-Serie 9000

Information von Kuemmel zum Thema LAN, WAN, Wireless ...

Heiß diskutierte Inhalte
Windows 10
Netzwerkkarte schaltet sich erst nach dem Logon ein (23)

Frage von DerWoWusste zum Thema Windows 10 ...

Windows Server
Seit IP Umstellung DC DNS Fehler (18)

Frage von Yaimael zum Thema Windows Server ...

Netzwerke
Mobile Einwahl IPSec VPN von iPhone iPad T-Mobile zur Pfsense (16)

Frage von Spitzbube zum Thema Netzwerke ...

Weiterbildung
gelöst Fest angestellter Admin oder Systemhaus Admin mit Kundenbetreuung? (15)

Frage von Voiper zum Thema Weiterbildung ...