Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Removing spaces from a variable in batch

I am writing a file to remove spaces from filenames in a folder and then put the result in a .txt file. I just get a result of "Echo is on." over and over.

This is what I have so far:

@echo ON
SET LOCAL EnableDelayedExpansion
For %%# in (*.*) do (
    SET var=%%~n#
    Set MyVar=%var%
    set MyVar=%MyVar: =%
    echo %MyVar%>>text.txt
)

Can someone tell me whats wrong?

like image 848
user2313522 Avatar asked Apr 29 '13 10:04

user2313522


3 Answers

Removing all spaces (not just leading and trailing) can be done without using setlocal enabledelayedexpansionwith the following line:

set var=%var: =%

This works by replacing all spaces in the string with the empty string.

Source: DOS - String Manipulation

like image 116
zr870 Avatar answered Oct 22 '22 22:10

zr870


The reason why you are getting ECHO is on. is because delayed expansion was not used, which caused the value of %var% and %MyVar% to be inserted before the for command is run, and since they were not defined at the start, empty variables were inserted in. When the echo %MyVar%>>text.txt was run, it was interpreted as echo >>text.txt. When echo is run without any arguments, it outputs whether echo is on or off, which is what you get in text.txt.

To fix the problem, you have to do two things:

First, there is something wrong with your second line. There is no space between set and local in setlocal. The second line should be SETLOCAL EnableDelayedExpansion.

Second, to use delayed expansion, you have to replace all %s in each variable with !, like !var! instead of %var%.

End result:

@echo ON
SETLOCAL EnableDelayedExpansion
For %%# in (*.*) do (
    SET var=%%~n#
    Set MyVar=!var!
    set MyVar=!MyVar: =!
    echo !MyVar!>>text.txt
)

You actually do not need to use a temporary variable in this case, you can just do SET MyVar=%%~n# and skip to set MyVar=!MyVar: =!.

like image 22
user2033427 Avatar answered Oct 22 '22 21:10

user2033427


The wrong thing is you've enabled the variable expansion (you wroted it bad...) and also you are not using it, when you use enabledelayedexpansion you need to write the variable names as this: !Variable! instead of this else: %Variable%

But you don't need to use it with this code:

@echo ON
For %%# in (*) do (
    SET "var=%%~n#"
    Call Set "MyVar=%%var: =%%"
    Call echo %%MyVar%%>>text.txt
)
like image 2
ElektroStudios Avatar answered Oct 22 '22 22:10

ElektroStudios