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 Frage zu Aktion print bei gawk

Mitglied: Kongootto

Kongootto (Level 1) - Jetzt verbinden

28.03.2012, aktualisiert 29.03.2012, 1927 Aufrufe, 1 Kommentar

Hallo Community,

mein Problem, welches mich verzeifeln, lässt bezieht sich auf die dynamische Auswertung einer .csv Datei durch gawk; anbei der betreffende Code:

01.
INFILE=${L2001HOME}/scripts/fibu/infile_uvnfin.csv 
02.
 
03.
cat $INFILE | while read line; do 
04.
        ANZAHL=`echo $line | gawk -F';' '{print NF}'`  #Anzahl der Wörter getrennt durch ; pro Zeile 
05.
        echo $ANZAHL 
06.
        for ((i=2; i<=$ANZAHL; i++)); do 
07.
                MANDANT=`echo $line | gawk -F';' '{print $i}'` #hier soll immer das i-te Wort pro Zeile ausgegeben werden ausgehende vom 2ten Wort 
08.
                echo $MANDANT 
09.
        done 
10.
done 
11.
 
Mir gelingt es einfach nicht das print $i beim Durchlauf der Schleife dynamisch mit gawk auszuwerten. Wenn ich print $2 oder $3 setzte habe ich zwar das Ergbenis was ich brauche; allerdings nicht dynmasich da eine Zeile 2..n Wörter enthalten kann.

Nachtrag: Ich habe auch schon sowas wie MANDANT=`echo $line | gawk -F';' '{print $"echo$i"}'` probiert; aber das haut nicht hin. Hat denn keiner eine Idee.


Ich hoffe jemand kann mir bei diesem, vermutlich ganz banalem, Problem helfen.

LG
Kongootto
Mitglied: Kongootto
29.03.2012 um 15:50 Uhr
Hallo,

hier nochmal der Verfasser: habe das Problem mitlerweile selbst gelöst: man kann gawk durch den Paramter -v eine Variable mitgeben; sieht dann in etwas so aus:

01.
cat $INFILE | while read line; do 
02.
        MANDANT=`echo $line | gawk -F';' '{print $1}'` #Mandantennummer der zu kopierenden Datei 
03.
        echo "Verteilen der Buchungslisten für Mandant $MANDANT:" >> $PROTO 
04.
 
05.
        #echo $line | gawk -F';' '{ for(i=2;i<=NF;i++)  print $i}' 
06.
        ZAEHLER=2 # die Listenverzeichnisse beginnen ab Spalte 2 
07.
        SPALTEN=`echo $line | gawk -F';' '{print NF}'` #Anzahl der Spalten 
08.
        while [ $ZAEHLER -le $SPALTEN ]; do #durchlaufen aller Spalten pro Zeile beginnend ab der 2ten 
09.
                LISTENVERZ=`echo $line | gawk -v PARAM="$ZAEHLER" -F';' '{print $PARAM}'` #Listernverzeichnis der aktuellen Spalte 
10.
                #echo $LISTENVERZ 
11.
                find -maxdepth 1 -type f  -name "*$MANDANT*"  -exec cp -v  \{\} /mnt/loga_app/listen/$LISTENVERZ/UVNFIN 1>>$PROTO 2>&1 \; 
12.
                ZAEHLER=$[$ZAEHLER+1] 
13.
        done 
14.
        echo "" >> $PROTO 
15.
done 
16.
 
Ist zwar nicht besonders schön aber funktioniert.

Falls jemand eine Idee hat wie man die ganze Funktionalität in awk abbildet, kann er sich ja nochmal melden.

Gruß
Kongootto
Bitte warten ..
Ähnliche Inhalte
Java

Frage zu Print When Expression im Jaspersoft Studio

Frage von helmuthelmut2000Java2 Kommentare

Hi, In einem Projekt in Jasper Report möchte ich folgendes ausgeben. Wenn zwei Felder auf einer Seite identisch sind, ...

Windows 7

PDF-Printer

gelöst Frage von malikaWindows 79 Kommentare

Guten Tag, ich habe einen W7 Pro 64-Bit PC auf dem Adobe PDF Printer fehlt. Ich habe versucht einen ...

Batch & Shell

Abfrage nach Änderungsdatum + Aktion

Frage von hoffi3dBatch & Shell5 Kommentare

Hallo zusammen, ich benötige eine Batch Datei, die bei zwei Dateien(Name ist bekannt und immer gleich, im Ordner gibt ...

Windows Server

Print server

Frage von EverestWindows Server8 Kommentare

Hallo zusammen, hat jemand eine Idee was es sein kann wenn die Drucker ab und zu wirre Zeichen drucken? ...

Neue Wissensbeiträge
Sicherheit

Zero Day-Schwachstelle im Internet Explorer - wird von APT bereits ausgenutzt

Information von kgborn vor 10 StundenSicherheit

Im Kernel des Internet Explorer scheint es eine Zero Day-Lücke zu geben, die von staatlichen Akteuren (APT) im Rahmen ...

Microsoft
Folder Security Viewer-Lizenzen zu gewinnen
Information von kgborn vor 10 StundenMicrosoft

Ich nehme das Thema mal in Absprache mit Frank hier auf, da es für den einen oder anderen Administrator ...

Hardware

Feueralarm killt Festplatten in Rechenzentrum - führt zu größerem Ausfall

Information von kgborn vor 10 StundenHardware10 Kommentare

Noch ein kleiner Beitrag für Administratoren, die in Rechenzentren aktiv sind - so als Fingerzeig. Denn es gibt Szenarien, ...

MikroTik RouterOS

Mikrotik Advisory: Vulnerability exploiting the Winbox port

Information von colinardo vor 10 StundenMikroTik RouterOS

Brand aktuell: Eine Schwachstelle im Winbox-Port bei Mikrotik Routern erlaubt das Auslesen der User-Datenbank der Router. Patch ist aktuell ...

Heiß diskutierte Inhalte
Linux
Linux Server oder Windows Server - lohnt eine Umstellung auf Linux und ebenso basierende SW bei einer langfristigen Planung?
Frage von motus5Linux23 Kommentare

Wir brauchen bei uns einen neuen Server. Dieser wird als Fileserver, Domäne Controller sowie Exchange Server verwendet. Wir versuchen ...

DSL, VDSL
ISP Wechsel auf Vodefone Koax, Gebäudeverkabelung nur per Cat 7
gelöst Frage von wusa88DSL, VDSL18 Kommentare

Hallo Zusammen, ich bin momentan bei Mnet als Glasfaser Kunde und möchte Preis/Leistungs-Technisch zu Kabel Deutschland / Vodafone wechseln. ...

Windows Server
Domänencontroller trennen
Frage von Akit57Windows Server13 Kommentare

Hallo, ich hoffe das mir hier jemand meine Frage trotz der spärlichen Informationen die ich geben kann beantworten kann: ...

LAN, WAN, Wireless
Kommunikation zwischen verschiedenen IP-Bereichen
Frage von DirkHoLAN, WAN, Wireless13 Kommentare

Hallo zusammen, von Unitymedia habe ich ein neues Modem (Connect Box) erhalten, das u.a. IPv4 aber keinen Bridge Mode ...