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

[文本处理] [分享]批处理只保留字符串里面的数字

【问题描述】

怎么提取字符串里面的数字,删除其它字符,
比如:123Bat456Home789论坛
结果:123456789
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

本帖最后由 WHY 于 2024-7-2 00:25 编辑
  1. dir /b /a-d *.txt | sed -r "/[0-9]/!d; s/[^0-9]+//g"
复制代码
  1. dir /b /a-d *.txt | gawk "/[0-9]/{gsub(/[^0-9]+/, \"\");print}"
复制代码
  1. PowerShell "(dir *[0-9]*.txt -File).BaseName -replace '\D+'"
复制代码
  1. @if(0)==(0) echo off
  2. dir /b /a-d *.txt | cscript //nologo //e:jscript "%~f0"
  3. pause & exit
  4. @end
  5. while (!WSH.StdIn.AtEndOfStream) {
  6.     var s = WSH.StdIn.Readline().replace(/\D+/g, '');
  7.     if (/./.test(s)) WSH.Echo(s);
  8. }
复制代码
假设文件名不超过256个字符。事实上,在默认情况下,Windows系统中的路径长度被限制在256个字符以内。
0x!s:~15,1!  应该是16
  1. @echo off
  2. for /L %%i in (0 1 9) do set _%%i=1
  3. for /f "delims=" %%i in ('dir /b /a-d *.txt ^| findstr "[0-9]"') do (
  4.     set "name=%%~ni"
  5.     setlocal enabledelayedexpansion
  6.     set "s=!name!"
  7.     for %%j in (128 64 32 16) do (
  8.         if "!s:~%%j!" NEQ "" (
  9.             set /a Len+=%%j
  10.             set "s=!s:~%%j!"
  11.         )
  12.     )
  13.     set "s=!s!FEDCBA9876543210"
  14.     set /a Len+=0x!s:~16,1!
  15.     for /L %%j in (0 1 !Len!) do (
  16.         set "s1=!name:~%%j,1!"
  17.         if defined _!s1! (
  18.             set "newName=!newName!!s1!"
  19.         )
  20.     )
  21.     echo;!newName!
  22.     endlocal
  23. )
  24. pause
复制代码
1

评分人数

    • 77七: 感谢分享技术 + 1

TOP


用11楼的4种方法作了用时测试(分别获取同一组约50个文件名的数值字段总和最终定向到各自的结果文件),分享一下结果数据如下...
   sed方法》用时0.37s(1.0)
   call方法》用时0.76s(2.1)
   jscript方法》用时0.95s(2.6)
   powershell方法》用时6.92s(18.7)
除了纯P的call方法之外,其余三种外部调用方法均经历两层循环体,虽然powershell功能丰富且代码轻量化,但用时最长
1

评分人数

    • 77七: 感谢分享技术 + 1

TOP

回复 16# buyiyang


   感谢大佬分享!我现在明白了为什么多了个数字1了。我自己尝试了一会,对$0,$1-n有了初步的了解,如 如果$2不为空,$1=$2,会多出第二列。
bat小白,请多指教!谢谢!

TOP

回复 15# ShowCode


   感谢大佬分享!测试代码结果正确。
bat小白,请多指教!谢谢!

TOP

回复 10# 77七


    $1^=$1是$1=$1^$1,$1是空值,在数值计算中被视为0,$1的0次方为1。

$1=$1是赋值语句,赋值语句的真假通过赋值后的值判断,$1为空即假, 不执行输出。
1

评分人数

    • 77七: 感谢分享技术 + 1

TOP

回复 10# 77七
  1. @echo off
  2. for /f "delims=" %%i in ('dir /b /a-d *.txt') do (
  3.     for /f "delims=" %%j in ('echo %%~ni ^| gawk -v OFS^="" -F "[^0-9]+" "NF+=0"') do (
  4.         echo [%%j]
  5.     )
  6. )
复制代码
测试代码之前请做好备份

TOP

回复 12# WHY


   感谢大佬分享!之前没有结果,我还以为是转义出现了问题,把引号内的等号也转义了,结果却多了个数字1。5楼的gawk代码我看不懂,尤其是$1,经过您指点,我大概理解是 批处理中的 第一列的意思,我尝试添加了第二列,结果居然是对的。
  1. echo;a1b2c3|gawk -vOFS="" -F"[^0-9]+" "$1=$1;$2=$2"
复制代码
bat小白,请多指教!谢谢!

TOP

回复 11# aloha20200628


   感谢大佬分享!正则替换很强大。
bat小白,请多指教!谢谢!

TOP

本帖最后由 WHY 于 2024-6-24 23:31 编辑

回复 10# 77七


    echo;a1|gawk -vOFS="" -F"[^0-9]+" "$1=$1"
这个时候 $1 值为空,可能 gawk 认为 "$1=$1" 赋值后条件不成立,所以没有输出。
  1. for /f %%i in ('echo;a123Bat456Home789 论坛^|gawk "{gsub(/[^0-9]+/, \"\")}1"') do echo [%%i]
复制代码
或者
  1. for /f %%i in ('echo;a123Bat456Home789 论坛^|gawk -vOFS^="" -F"[^0-9]+" "NF=NF"') do echo [%%i]
复制代码
试试。
1

评分人数

    • 77七: 感谢分享技术 + 1

TOP

本帖最后由 aloha20200628 于 2024-6-24 17:36 编辑


借8楼旧帖新续,也给几个版本仅供参考,示例题型》提取并链接当前目录中全部文本文件名包含的数值字段
一。采用纯P递归方法
二。调用jscript正则替换方法
三。调用sed.exe正则替换方法
四。调用powershell正则替换方法
  1. @set @x=1 /* &@echo off &setlocal
  2. for %%F in (*.txt) do (
  3. set "_F=" &(call :get#n "%%~nF")
  4. for /f %%a in (' cscript /nologo /e:jscript "%~f0" "%%~nF" ') do echo,%%a
  5. for /f %%a in (' echo,"%%~nF"^|sed "s/[^0-9]//g" ') do echo,%%a
  6. for /f %%a in (' powershell " '%%~nF' -replace '[^\d]' " ') do echo,%%a
  7. )
  8. endlocal&pause&exit/b
  9. :get#n
  10. if "%~1"=="" echo,%_F%&exit/b
  11. set s=%~1
  12. set c=%s:~,1%
  13. if "%c%" geq "0" if "%c%" leq "9" set _F=%_F%%c%
  14. call :get#n "%s:~1%"
  15. exit/b
  16. */
  17. v=WSH.arguments, WSH.echo(v(0).replace(/[^\d]/g,'')), WSH.quit();
复制代码
1

评分人数

    • 77七: 感谢分享技术 + 1

TOP

本帖最后由 77七 于 2024-6-24 11:40 编辑

回复 9# ShowCode


   感谢大佬帮助!我测试了以字母开头的文件名,结果为空,比如 a1.txt。用5楼代码 测试 字母开头的字符串,结果同样为空。
bat小白,请多指教!谢谢!

TOP

回复 8# 77七
  1. @echo off
  2. for /f "delims=" %%i in ('dir /b /a-d *.txt') do (
  3. for /f "delims=" %%j in ('echo %%~ni ^| gawk -v OFS^="" -F "[^0-9]+" "$1=$1"') do (
  4. echo [%%j]
  5. )
  6. )
复制代码
C:\Test>dir /b *.txt
123Bat456Home789.txt

C:\Test>1.bat
[123456789]

C:\Test>gawk --version
GNU Awk 5.1.0, API: 3.0
测试代码之前请做好备份

TOP

回复 5# hfxiang


   大佬,请教下,我把命令写到for里面,为什么结果之前多了一个数字 1 呢?
  1. @echo off
  2. cd.>a1.txt
  3. for /f "delims=" %%i in ('dir /b /a-d *.txt') do (
  4. for /f "delims=" %%j in ('echo;%%~ni^|gawk -vOFS^="" -F"[^0-9]+" "$1^=$1"') do (
  5. echo [%%j]
  6. )
  7. )
  8. pause
复制代码
bat小白,请多指教!谢谢!

TOP

回复 5# hfxiang


再来个sed
  1. echo 123Bat456Home789论坛 | sed "s/[^0-9]//g"
复制代码
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

返回列表