我想从txt文件中删除所有空格和制表符。以下是我尝试执行此操作的代码:
for /F "delims=" %%a in (CODE_CHECK.txt) do (
set one=%%a
set one=%one:=%
) >> CODE_CHECK_2.txt
示例文件行:
ONE VIEW
TWO PACKEGE BODY
代码之后应该是:
ONEVIEW
TWOPACKEGEBODY
假设您使用的是Windows平台,由于您提供的代码和附带的标签...
以下qazxsw poi示例将删除空格和制表符,并删除任何空行:
batch-file
要使用@If Exist "CODE_CHECK.txt" (For /F Delims^=^ EOL^= %%A In ('More /T1 "CODE_CHECK.txt"')Do @Set "$=%%A"&Call Echo(%%$: =%%)>"CODE_CHECK_2.txt"
维护任何空行,您需要更像这样的东西:
batch-file
在这个例子中我删除了@If Exist "CODE_CHECK.txt" (For /F "Tokens=1*Delims=]" %%A In ('More "CODE_CHECK.txt"^|Find /V /N ""')Do @Set "$= %%B"&Call Echo(%%$: =%%)>"CODE_CHECK_2.txt"
的/T1
选项,我不确定它的包含是否效率更高或更低
您也可以使用More
,(如果需要,输入和输出文件可以相同):
powershell
您还可以从(GC 'CODE_CHECK.txt') -Replace '\s',''|SC 'CODE_CHECK_2.txt'
运行powershell版本:
batch-file
在这个版本中,我使用@PowerShell -NoP "(GC 'CODE_CHECK.txt') -Replace ' |\t',''|SC 'CODE_CHECK_2.txt'"
作为' |\t'
的替代品。
鉴于文件保存少于64K行,每行长度小于8K字节/字符,不需要保留空行,并且文件是ASCII / ANSI编码的DOS / Windows样式换行符,你可以下列:
'\s'
这是一种保留空行的方法(其余限制仍然适用):
@echo off
setlocal EnableExtensions DisableDelayedExpansion
rem // Write output to another file:
> "CODE_CHECK_2.txt" (
rem /* Read file by `more` which replaces TABs by SPACEs;
rem then parse the output by `for /F` (skipping empty lines): */
for /F delims^=^ eol^= %%L in ('more "CODE_CHECK.txt"') do (
rem // Store current (non-empty) line:
set "LINE=%%L"
rem /* Toggle delayed expansion to be able to write and read
rem a variable in the same block of code and to preserve `!`: */
setlocal EnableDelayedExpansion
rem // Replace every SPACE by nothing, hence remove it:
echo(!LINE: =!
endlocal
)
)
endlocal
exit /B