[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文本处理] 批处理如何删除文本中第二个特定字符串后面的内容?

修改之前文本:
[56sdfg21sg312]3adf12as
f11h[3af123asf121g]
faws5ef2f
[
fasd35r
]
[3a3sdf2f
hgadf3]

修改之后:
[56sdfg21sg312]3adf12as
f11h[3af123asf121g]


就是要删除文本中第二个]后面的所有的内容。格式不变。找了半天不知道咋写,真心求教!

你的文件较特殊可以这样:
纯P
  1. @echo off & cd /d "%~dp0"
  2. (for /f "delims=" %%a in (00.txt) do echo %%a|findstr ".*\[.*\].*">nul && echo %%a)>ok.txt
  3. pause
复制代码
PS版 xxx.ps1
  1. (gc 00.txt|%{if($_ -match '.*\[.*\].*'){$_}})>ok.txt
  2. pause
复制代码

TOP

本帖最后由 WHY 于 2018-11-22 19:03 编辑

PowerShell
  1. $arr = type a.txt -Delimiter ']' -ReadCount 0;
  2. sc b.txt -Value ($arr[0]+$arr[1])
复制代码

TOP

返回列表