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

[文本处理] 批处理如何提取每行的数字部分,没有数字就写成123456

批处理如何提取每行的数字部分,没有数字就写成123456
a文本
gogo0913
great003
great521
gs021872
guijun
linlin
提取出来后的b文本应该是
0913
003
521
021872
123456
123456

弄了好几天,搞不定啊

使用第三方工具 sed 的话很容易:
  1. sed "s/[^0-9]//g;s/^$/12345/" a.txt>b.txt
复制代码

TOP

  1. gawk "{if($0~/[0-9]/)gsub(/[^0-9]/,\"\");else $0=123456;print}" a.txt > b.txt
复制代码

TOP

  1. @echo off
  2. ::逐字比对,效率很低。
  3. for /f "delims=" %%a in (a.txt) do (
  4.   set "str=%%a"
  5.   setlocal enabledelayedexpansion
  6.   echo %%a|findstr "[0-9]">nul&&(call :loop&echo !result!)||echo 123456
  7.   endlocal
  8. )
  9. pause&exit /b
  10. :loop
  11. set "chr=%str:~0,1%"
  12. echo %chr%|findstr "[0-9]">nul&&set result=%result%%chr%
  13. set "str=%str:~1%"
  14. if "%str%"=="" goto :eof
  15. goto loop
复制代码

TOP

返回列表