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, 8932 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 ...

Neue Wissensbeiträge
Batch & Shell

Batch - ein paar Basics die man kennen sollte

Tipp von Pedant zum Thema Batch & Shell ...

Microsoft

Restrictor: Profi-Schutz für jedes Window

(6)

Tipp von AlFalcone zum Thema Microsoft ...

Batch & Shell

Batch zum Zurücksetzen eines lokalen Profils

Tipp von Mr.Error zum Thema Batch & Shell ...

Heiß diskutierte Inhalte
Microsoft Office
Saubere HTML aus Word-Dokument (16)

Frage von peterpa zum Thema Microsoft Office ...

Router & Routing
ASUS RT-N18U mit VPN Client hinter Fritzbox - Portforwarding (15)

Frage von marshall75000 zum Thema Router & Routing ...

Hosting & Housing
gelöst Webserver bei WIX, aber DNS Server wo anders (9)

Frage von laster zum Thema Hosting & Housing ...