復(fù)制代碼 代碼如下:
@echo off
:: 去掉左空格
::
::
set "str= ab c>! "
for /f "tokens=*" %%i in ("%str%") do echo "☆%%i☆"
pause
goto :eof
@echo off
:: 去掉左空格
::
::
set "str= ab c>! "
:intercept
if "%str:~0,1%"==" " set "str=%str:~1%"goto intercept
echo "☆%str%☆"
pause
goto :eof
@echo off
:: 去掉右空格
::
::
set "str= ab c>! "
:intercept
if "%str:~-1%"==" " set "str=%str:~0,-1%"goto intercept
echo "☆%str%☆"
pause
goto :eof
@echo off
:: 去掉首尾空格空格
::
::
set "str= ab c>! "
:intercept_left
if "%str:~0,1%"==" " set "str=%str:~1%"goto intercept_left
:intercept_right
if "%str:~-1%"==" " set "str=%str:~0,-1%"goto intercept_right
echo "☆%str%☆"
pause
goto :eof
@echo off
:: 去掉所有空格空格
::
::
set "str= ab c>! "
set "str=%str: =%"
echo "☆%str%☆"
pause
goto :eof
@echo %dbg% off
cls echo. echo.
:Redtek 2006 去左、右含有空格的變量試驗與另類方法實現(xiàn)演示
:: 為演示與另做它用方便,所以“標(biāo)簽代碼段”內(nèi)的代碼都可以獨立使用
::
set "var= My name is Redtek "
rem 注:下面 Call 中的參數(shù)是無引號的,利用參數(shù)以逗號空格等做為分隔的特性
call :去左側(cè)空格 %var%
echo. echo.
call :去右側(cè)空格 "%var%"
rem 去字符串中的左、右空格
rem 為演示與另做它用的方便,下面步驟將重新編寫去左右空格的代碼段,可以獨立使用。
echo. echo.
call :去兩邊空格 "%var%" %var%
goto :eof
:去左側(cè)空格
rem 利用替換原理,將變量 var 中 以 ^%1變量內(nèi)容開頭字串的左邊一切替換為^1本身
rem 因為被 Call 過來以后,參數(shù)中的空格就全“丟了”(利用參數(shù)分隔的特性),
rem 所以,自然那個要被定位的 ^%1 左邊的空格也就全沒了。
call set "去左空格后的變量=%%var:*%1=%1%%
echo 原字符串: [%var%]
echo 去左側(cè)空格后的字符串: [%去左空格后的變量%]
goto :eof
:去右側(cè)空格
rem 將結(jié)果賦值給變量,這個變量可以隨便調(diào)用。
rem ~nx 是利用了“將變量擴展到一個文件名”的特性,
rem 既然是合法的文件名,當(dāng)然文件名后面的空格是無效且無用的~:)
set 去右空格后的變量=%~nx1
echo 原字符串: [%var%]
echo 去右側(cè)空格后的字符串: [%去右空格后的變量%]
goto :eof
:去兩邊空格
rem 原理:先去左邊空格,再去右邊空格,相當(dāng)于上面演示代碼的合用:)
rem 在假如沒有上面兩段去左和去右空格的代碼情況下,下面獨立演示:
set 去左右空格后的變量=%~nx1
call set "去左右空格后的變量=%%去左右空格后的變量:*%2=%2%%"
echo 原字符串: [%var%]
echo 去左右空格后的字符串: [%去左右空格后的變量%]
goto :eof