Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

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

Mit Batch csv Dateien bearbeiten

Frage Entwicklung Batch & Shell

Mitglied: 65999

65999 (Level 1)

17.09.2008, aktualisiert 09.11.2016, 8887 Aufrufe, 1 Kommentar

Ich habe 2 Dateien, einmal eine Batch Datei und eine csv Datei: Die Batch Datei soll den eingegebenen Namen in der csv Datei finden und den Anwender abfragen, welche Installationsvariante der Name bekommen soll. Anschließend überprüft die Batch Datei ob der Name die richtige Installationsvariante hat, falls nein, trägt er den Namen in die gewählte Installationsvariante ein.

Jedes Feld steht für eine Installationsvariante, das Script trägt dann automatisch den Namen ein, falls in der Batch die jeweilige Installationsvariante gewählt wurde:

01.
X;Mustermann;X;X;X;X;X; 
02.
X;X;X;X;Mustermann2;X;X;
Die Batchdatei sieht so aus:
01.
@echo off & setlocal 
02.
 
03.
Set sapcsv=C:\sap.csv 
04.
set /P name= Bitte Name eingeben, der veraendert werden soll:  
05.
set /P Variante= Bitte Installationsvariante eingeben:  
06.
 
07.
For /f "delims=; tokens=1-7" %%a in ('Find /i "%name%" "%sapcsv%"') do ( 
08.
Set newline= 
09.
set t1=X 
10.
set t2=X 
11.
set t3=X 
12.
set t4=X 
13.
set t5=X 
14.
Set t6=X 
15.
Set t7=X 
16.
 
17.
If /i "%Variante%"== "A" Set "t1=%name%" 
18.
If /i "%Variante%"== "B" Set "t2=%name%"  
19.
If /i "%Variante%"== "C" Set "t3=%name%" 
20.
If /i "%Variante%"== "D" Set "t4=%name%"  
21.
If /i "%Variante%"== "E" Set "t5=%name%"  
22.
If /i "%Variante%"== "F" Set "t6=%name%"  
23.
If /i "%Variante%"== "G" Set "t7=%name%"  
24.
25.
 
26.
Set newline=%t1%;%t2%;%t3%;%t4%;%t5%;%t6%;%t7%; 
27.
 
28.
Find /v /i "%name%" "%sapcsv%" >"%temp%\temp.csv" 
29.
echo %newline%>>"%temp%\temp.csv" 
30.
Copy /y "%temp%\temp.csv" "%sapcsv%" 
31.
 
32.
pause
Im Prinzip funktioniert das ganze so wie es funktionieren soll, doch es gibt noch 1 Problem: Frage gelöscht

Wäre nett, wenn ihr mir helfen könntet.
Mitglied: bastla
17.09.2008, aktualisiert 10.11.2016
Hallo user47444!

Zum 1.: Verwende "findstr" anstelle von "find"

Zum 2.: Suche nach zB ";Schmidt;" (bzw, falls der Name auch am Anfang oder Ende der Zeile stehen kann, unter Verwendung von "findstr" mit "^Schmidt;" oder "Schmidt$" bzw den Schaltern "/b" oder "/e")

Grüße
bastla
Bitte warten ..
Ähnliche Inhalte
Batch & Shell
gelöst Batch : alle Dateien eines Ordners bearbeiten (1)

Frage von deguonkel zum Thema Batch & Shell ...

Batch & Shell
gelöst Auslesen und Vergleichen Zweiter CSV Dateien Powershell (7)

Frage von Hainoon zum Thema Batch & Shell ...

VB for Applications
gelöst VBA Skript zum Import von CSV-Dateien (8)

Frage von Toepfi zum Thema VB for Applications ...

Neue Wissensbeiträge
Sicherheits-Tools

Sicherheitstest von Passwörtern für ganze DB-Tabellen

(1)

Tipp von gdconsult zum Thema Sicherheits-Tools ...

Peripheriegeräte

Was beachten bei der Wahl einer USV Anlage im Serverschrank

(9)

Tipp von zetboxit zum Thema Peripheriegeräte ...

Windows 10

Das Windows 10 Creators Update ist auf dem Weg

(6)

Anleitung von BassFishFox zum Thema Windows 10 ...

Heiß diskutierte Inhalte
Exchange Server
Exchange 2016 Standard Server 2012 R2 Hetzner Mail (36)

Frage von Datsspeed zum Thema Exchange Server ...

Batch & Shell
gelöst ZIP-Archive nach Dateien durchsuchen und Pfade ausgeben (33)

Frage von evinben zum Thema Batch & Shell ...

Verschlüsselung & Zertifikate
Mit Veracrypt eine zweite interne (non-system) Festplatte verschlüsseln (10)

Frage von Bernulf zum Thema Verschlüsselung & Zertifikate ...

C und C++
Methode multiple return values (8)

Frage von mayho33 zum Thema C und C ...