• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 276
  • Last Modified:

DOS batch file, change numbers within a text file

I have ~2,500 text files like this:

10.00000
0
0
-10.00000
2827500.250
2179999.750

I need to modify the last two lines:

Line [5]  + 4.75
Line [6]  - 4.75

many thanks
0
hgj1357
Asked:
hgj1357
3 Solutions
 
Raheman M. AbdulSenior Infrastructure Support Analyst & Systems DeveloperCommented:
The following script changes the last lines of the *.txt files. For safety you can make a copy of all your .txt files before you run the following script.

Start -> run -> Powershell_ise (Enter)


Paste the following : and rename the location of folder c:\drivers to your location
---------------------------------
$files = Get-ChildItem C:\DRIVERS -Filter *.txt
foreach ($file in $files)
{
$text=gc $file.Fullname
$text[-2]="+4.75"
$text[-1]="-4.75"
$text > $file.FullName

}
---------------------------------
Press F5
0
 
hgj1357Author Commented:
I'm not familiar with Powershell.

Where do I paste, and how do I run it .  Thanks
Powershell.jpg
0
 
Dan CraciunIT ConsultantCommented:
I think the OP wants those values modified. In which cases the script should be:

$text[-2] = 4.75 + $text[-2]
$text[-1] = -4.75 + $text[-1]

Note that you need the 4.75 + $text to force Powershell to add numbers, cause $text + 4.75 will concatenate strings.

HTH,
Dan
0
Problems using Powershell and Active Directory?

Managing Active Directory does not always have to be complicated.  If you are spending more time trying instead of doing, then it's time to look at something else. For nearly 20 years, AD admins around the world have used one tool for day-to-day AD management: Hyena. Discover why

 
Dan CraciunIT ConsultantCommented:
@hgj1357: you need to paste it in the lower window
0
 
hgj1357Author Commented:
How do I run it?
0
 
Dan CraciunIT ConsultantCommented:
BTW, if you want to keep the 3 decimals (as in 2827500.250) you need to modify the code like this:
Param (
[string]$inputPath = "X:\path\to\your\files"
)

$files = Get-ChildItem $inputPath -Filter *.txt
foreach ($file in $files)
{
    $text=gc $file.Fullname
    $text[-2] = "{0:F3}" -f (4.75 + $text[-2])
    $text[-1] = "{0:F3}" -f (-4.75 + $text[-1])
    $text > $file.FullName
}

Open in new window

Save the code as whatever.ps1 and run it as whatever.ps1 X:\your\path

OR, change X:\path\to\your\files to your actual path, paste the entire script in the lower pane of the Powershell ISE window and then press ENTER.
0
 
Dan CraciunIT ConsultantCommented:
run script
0
 
hgj1357Author Commented:
This works - nearly.  The resultant text file is some kind of ANSI format that I can not use further. (In AutoCAD).  If I open and save as ANSI encoded file type, it then works again.  Is there a way to bulk change the encoding type to ANSI?
0
 
Dan CraciunIT ConsultantCommented:
Run this in powershell:

Get-ChildItem "X:\path\to" -Filter *.txt | % { (Get-Content $_.fullname) | Set-Content $_.fullname -Force -Encoding ASCII}

Open in new window


Of course, change X:\path\to to your actual path.
0
 
hgj1357Author Commented:
I used type File>Newfile.txt to fix issue.

All good.

Thanks
0
 
Gerwin Jansen, EE MVETopic Advisor Commented:
Removed MSDOS Topic and added Powershell Topic since the accepted solution is not an MSDOS based solution.

Gerwin Jansen
EE Topic Advisor
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Protect Your Employees from Wi-Fi Threats

As Wi-Fi growth and popularity continues to climb, not everyone understands the risks that come with connecting to public Wi-Fi or even offering Wi-Fi to employees, visitors and guests. Download the resource kit to make sure your safe wherever business takes you!

Tackle projects and never again get stuck behind a technical roadblock.
Join Now