新行作为FOR循环的分隔符

时间:2013-03-26 15:43:57

标签: loops batch-file cmd window delimiter

我是批处理脚本的新手,我正在尝试解析具有由新行分隔的对的键值(种类)的文件。例如:

the value of abc
1234
the value of def
5678
the value of ghi
9876

我想使用新行作为分隔符来读取此文件,以便我可以访问这些值。

这样的东西
for /f "tokens=1,2,3 delims='\n'" %%i in ('findstr /C:the value of abc 'filepath') do echo %%j

6 个答案:

答案 0 :(得分:3)

@ECHO OFF
SETLOCAL
SET "prevline="
FOR /f "delims=" %%z IN (tvabc.txt) DO (
 IF DEFINED prevline (
  FOR /f "tokens=1-6" %%a IN ('echo %%prevline%% %%z') DO (
   ECHO %%a %%b %%c %%d %%e %%f
   )
  SET "prevline="
  ) ELSE (SET prevline=%%z)
)
如果您需要输出两个连续行中的每个标记,

应该完成这项工作。如果我们列出了所需的输出,而不是从不起作用的代码中猜测,那将会容易得多。

本质上,此代码保存一行的内容,然后检测到第二行已被读取,因为定义了保留前一行的变量。在这种情况下,for/f用于标记两行的连接。

答案 1 :(得分:3)

我只是把它作为一个选项:

for /F delims^=^ eol^= %%i in ('findstr /C:the value of abc 'filepath') do echo %%i

答案 2 :(得分:2)

您无法将“新行”设置为分隔符。试试这个:

@echo off &setlocal
for /f "tokens=1*delims=:" %%i in ('findstr /NC:"the value of abc" "filepath"') do set /a count=%%i
if defined count for /f "skip=%count%tokens=1*delims=:" %%i in ('findstr /N "^" "filepath"') do if not defined value set "value=%%j"
echo.%value%
endlocal

答案 3 :(得分:1)

不确定在获得这些名称/价值对之后你会做什么,但是如果你打算在Powershell中做,那就做好并从创建对象开始:

$file = 'c:\somedir\somefile.txt'

[regex]$regex = @'
(?ms)the value of (\S+)
(\d+)
'@

#Choose one
$text = Get-Content $file -Raw  # V3 Only
$text = [IO.File]::ReadAllText($file)  # V2 or V3


$regex.matches($text) |
foreach {
   New-object PSObject -Property @{
                                   Name = $_.groups[1].value
                                   Value = $_.groups[2].value
                                  }
        }|
  Select Name,Value |
  Format-Table -AutoSize

Name Value
---- -----
abc  1234 
def  5678 
ghi  9876 

答案 4 :(得分:0)

你怎么看?在powershell中:

(get-content .\essai.txt)[(Select-String .\essai.txt -Pattern "the value of abc").LineNumber]

显示模式后面的下一行。

答案 5 :(得分:0)

我通常使用给定的批处理命令来读取文件中的每一行

FOR /F "delims=" %%G IN (test.txt) DO (
    ECHO %%G
)

在这里,"delim="可以解决问题。