Solved

Batch file to comment specific lines into a text file

Posted on 2012-12-26
4
766 Views
Last Modified: 2012-12-28
Hi Experts,

Happy cristmas for all, and hope we find all the happiness, health and money (lotof money $$$)  :D

Please, i need to do a batch file like that :

MyBatchFile.bat    file.txt    FileWithLineToComment.txt

Where :

FileWithLineToComment.txt
     it's a text file, this one containall the lines text (not numbers of line) that we need to comment.

MyFile.txt:
   Containe all the lines

MyBatchFile.bat
   Is the program that i need to write. This batch file will :
  1- open FileWithLineToComment.txt, and read line by line
  2- for each line we read, we will search it into the "MyFile.txt"
  3- one time we find it we will add " // " in the first of the find line, and like that it will be
comment.
 


Exemple :

MyFile.txt Containe :
123
34
12
153
123
757

Open in new window

FileWithLineToComment.txt
12
757

Open in new window


if i do this command line :
MyBatchFile.bat    file.txt    FileWithLineToComment.txt

Open in new window


MyFile.txt   will be like that:
 
123
34
//12
153
123
//757

Open in new window


Hope you can help me

Thanks
0
Comment
Question by:Joesephlebon
  • 2
4 Comments
 
LVL 43

Expert Comment

by:Steve Knight
ID: 38723048
Are these real world examples, or are they going to be text files with any amount of data, words, spaces, commas, other characters potentially on the line.  Same for the list of lines to check?

Are there any blank lines etc. in the file that are important?

And just to check it seems you are checking the whole line to comment, i.e. if your string was found part way across the line.

If all of those end up being just like your answer it is a relatively simple for loop but no point writing that if not.

thanks

Steve
0
 
LVL 54

Accepted Solution

by:
Bill Prew earned 500 total points
ID: 38727187
This should give you a pretty good place to start, let me know what questions you have.

@echo off
setlocal EnableDelayedExpansion

REM Make sure required parms were supplied
if "%~1" EQU "" (
  echo No data file specified to process
  exit /b
)
if "%~2" EQU "" (
  echo No comment file specified to process
  exit /b
)

REM Get input file and comment file from command line parms
set Filename=%~1
set Comments=%~2

REM Define name for temporary file
set Outfile=%Temp%\%~nx1

REM Send changed file to tem file for now
(
  REM Read each line of file
  for /F "usebackq tokens=*" %%L in ("%Filename%") do (
    REM Read each line from comment file
    set MakeComment=N
    for /F "usebackq tokens=*" %%C in ("%Comments%") do (
      REM If this line is to be commented flag it

      if /I "%%L" EQU "%%C" set MakeComment=Y
    )
    if "!MakeComment!" EQU "Y" (
      echo.//%%L
    ) else (
      echo.%%L
    )
  )
)>"%Outfile%"

if exist "%Outfile%" (
  copy /Y "%Outfile%" "%Filename%" >NUL
  del "%Outfile%" >NUL
)

Open in new window

~bp
0
 

Author Closing Comment

by:Joesephlebon
ID: 38728037
Thanks so much Experts ;)
It's work fine :)
0
 
LVL 54

Expert Comment

by:Bill Prew
ID: 38728305
Welcome, glad that was useful.

~bp
0

Featured Post

Resolve Critical IT Incidents Fast

If your data, services or processes become compromised, your organization can suffer damage in just minutes and how fast you communicate during a major IT incident is everything. Learn how to immediately identify incidents & best practices to resolve them quickly and effectively.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

TOMORROW TOMORROW.BAT is inspired by a question I get asked over and over again; that is, "How can I use batch file commands to obtain tomorrow's date?" The crux of this batch file revolves around the XCOPY command - a technique I discovered w…
Use this article to create a batch file to backup a Microsoft SQL Server database to a Windows folder.  The folder can be on the local hard drive or on a network share.  This batch file will query the SQL server to get the current date & time and wi…
Established in 1997, Technology Architects has become one of the most reputable technology solutions companies in the country. TA have been providing businesses with cost effective state-of-the-art solutions and unparalleled service that is designed…
I've attached the XLSM Excel spreadsheet I used in the video and also text files containing the macros used below. https://filedb.experts-exchange.com/incoming/2017/03_w12/1151775/Permutations.txt https://filedb.experts-exchange.com/incoming/201…

820 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question