使用批处理编辑文本文件



如果在textfile2.txt 中找到单词,我想在textfile1.txt中编辑它

textfile1.text包含

264392  ja_JP   9000    -0.2620 0   2   0   どれ
264393  ja_JP   9000    0.5577  0   2   0   最低
264394  ja_JP   9000    0.4761  0   2   0   明け
264395  ja_JP   9000    -0.1549 0   2   0   消費
264396  ja_JP   9000    -0.2028 0   2   0   ばな
264399  ja_JP   9000    -0.1141 0   2   0   覧下

textfile2.txt包含

264394  ja_JP   9000    0.4761  0   2   0   明け
264395  ja_JP   9000    -0.1549 0   2   0   消費
264396  ja_JP   9000    -0.2028 0   2   0   ばな

textfile1.text现在应该是

264392  ja_JP   9000    -0.2620 0   2   0   どれ
264393  ja_JP   9000    0.5577  0   2   0   最低
#264394 ja_JP   9000    0.4761  0   2   0   明け
#264395 ja_JP   9000    -0.1549 0   2   0   消費
#264396 ja_JP   9000    -0.2028 0   2   0   ばな
264399  ja_JP   9000    -0.1141 0   2   0   覧下

只有行开头的数字才是重要的

我已经搜索了一些代码,但它将编辑后的数字放在文件的底部,而不是编辑文件

提前感谢:)

此方法不要求文件具有任何排序顺序。只要FOR /F命令正确处理日语字符,它就应该工作。

@echo off
setlocal EnableDelayedExpansion
rem Read textfile2 and create an array with the first column
for /F %%a in (textfile2.txt) do set "file2[%%a]=1"
rem Process textfile1
(for /F "tokens=1*" %%a in (textfile1.txt) do (
   if defined file2[%%a] set /P "=#" < NUL
   echo %%a %%b
)) > textfile1.new
move /Y textfile1.new textfile1.txt > NUL

我假设两个文件都已经排序,如您的示例所示,没有任何文件包含!字符,并且第二列始终存在。

假设FOR/F正确地处理了日语字符(我只是不知道),那么以下操作应该有效:

@echo off
setlocal enableDelayedExpansion
set "B="
<"textfile2.txt" (
  for /f "usebackq delims=" %%A in ("textfile1.txt") do (
    if not defined B (
      set /p "B="
      for /f %%B in ("!B! x") do set "B=%%B"
    )
    for /f "tokens=1*" %%C in ("%%A") do if !B! equ %%C (
      echo #%%C %%D 
      set "B="
    ) else (
      echo %%A
    )
  )
) >"textfile1.txt.new"
move /y "textfile1.txt.new" "textfile1.txt" >nul

以上是用于合并两个排序文本文件的技术的变体。

最新更新