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

[文本处理] 求助批处理对于不确定列数数据的处理

如题

我这边有几行16进制的数据
0760        20 66 64 62 32 3a 32 63  32 36 3a 66 34 65 34 3a    fdb2:2c26:f4e4:
0770        30 3a 63 64 65 3a 34 62  39 30 3a 39 62 36 30 3a   0:cde:4b90:9b60:
0780        35 39 64 31 0d 0a                                  59d1..
类似于这种,有某行的长度是与其他行的长度不同的

我的目标是取出每行中间的16进制数
我之前的写法是
for /f "tokens=1-17" %a in (hex.txt) do echo %a%b%c%d%e%f%g%h%i%j%k%l%m%n%o%p%q
但是这种写法无法处理最后一行 因为列数的数据对不上

之前的想法是在文件后面添加数据,但是总感觉更麻烦
另一种思路是对于文件的最后一行单独处理,但是最后一行的长度也是不确定的,处理起来也很麻烦。


在论坛里面翻了很多帖子,没找到特别合适的解决办法,windows下的命令操作起来太局限了

所以请大佬赐教下,对于这种情况有什么好的思路吗,我也想学习学习
谢谢大家🙏

  1. powershell "(gc 'hex.txt') -replace '^[^\s]+\s+|\s{3,}.*$'"
复制代码

TOP

回复 2# idwma

谢谢大佬的回答 我这边的环境要求的比较严格 有时候会有win03的环境 所以powershell用不了
   

TOP

  1. @echo off&setlocal enabledelayedexpansion
  2. for /f "delims=" %%i in (hex.txt) do (
  3. set str=%%i
  4. set str=!str:   =★!
  5. for /f "tokens=2 delims=★" %%i in ("!str!") do (
  6. echo %%i>>hex2.txt
  7. )
  8. )
复制代码

TOP

  1. @echo off
  2. setlocal enabledelayedexpansion
  3. (for /f "delims=" %%a in (hex.txt) do (
  4.   set str=
  5.   set var=
  6.   for %%i in (%%a) do (
  7.     if defined var (
  8.       if not defined str (
  9.         set str=%%i
  10.       ) else (
  11.         set str=!str! !var!
  12.       )
  13.     )
  14.     set var=%%i
  15.   )
  16.   echo,!str:* =!
  17. ))>new_hex.txt
  18. pause
复制代码

TOP

返回列表