Board logo

标题: [文本处理] 【已解决】批处理如何删除右侧最小数值的行 [打印本页]

作者: 思想之翼    时间: 2023-7-13 20:02     标题: 【已解决】批处理如何删除右侧最小数值的行

本帖最后由 思想之翼 于 2023-7-13 22:32 编辑

文本1.txt记录数值如下
331        22
445        1
550        3336
653        20999
567        2
000        1
009        1
888        1

问题:如何用纯批或gawk等第三方工具,删除右侧最小数值的行?

结果2.txt为
331        22
550        3336
653        20999
567        2
作者: pd1    时间: 2023-7-13 20:37

  1. <# :
  2. @echo off
  3. powershell -NoProfile -ExecutionPolicy bypass "Get-Content -literal '%~f0' |Out-String|Invoke-Expression"
  4. pause
  5. #>
  6. $min=(gc .\1.txt|%{$_.Split(" ")[-1]}|sort)[0]
  7. gc .\1.txt|?{$_.Split(" ")[-1] -ne $min }|%{$_ >>2.txt}
复制代码

作者: WHY    时间: 2023-7-13 21:51

  1. gawk -v min="10000000000" "NR==FNR {min=min>$2?$2:min} NR>FNR && $2!=min" 1.txt 1.txt > 2.txt
复制代码
  1. PowerShell "$arr = gc 1.txt -ReadCount 0; $min = ($arr -replace '^\S+' | measure -Min).Minimum; $arr -notMatch ('\b' + $min + '$')" > 2.txt
复制代码

作者: 77七    时间: 2023-7-14 06:34

  1. @echo off
  2. setlocal enabledelayedexpansion
  3. set n=100000000
  4. for /f "useback tokens=2 delims= " %%a in ("1.txt") do (
  5. if %%a lss !n! (
  6. set n=%%a
  7. )
  8. )
  9. findstr /vec:" %n%" 1.txt > 2.txt
  10. endlocal
  11. pause
复制代码





欢迎光临 批处理之家 (http://bbs.bathome.net/) Powered by Discuz! 7.2